

# AN5023 Application note

L9680 airbag system IC

## Introduction

The L9680 is an advanced airbag system chip solution targeted for airbag high-end market.

This device is family compatible with the L9678, L9679 and L9679E devices.

This document is an integration of the application note (AN4437) developed for L9678 and available in STMicroelectronics web site.

Safety system integration is enabled through higher power supply currents and integrated active wheel speed sensor interface.

System designs can be completed using L9680, SPC560Px microcontroller and eventually companion chip i.e. L9679E.

The active wheel speed interface is shared with the PSI-5 satellite interface to create a generic remote safety sensor interface compliant to both systems.

Contents AN5023

# **Contents**

| 1 | Deta | il feature       | 9S                                               | 8    |
|---|------|------------------|--------------------------------------------------|------|
| 2 | Devi | ice mech         | anization overview                               | 9    |
|   | 2.1  | Externa          | al components summary                            | 10   |
|   |      | 2.1.1            | Component layout considerations                  | 10   |
|   |      | 2.1.2            | ESD and SPIKE protection                         | 13   |
|   |      | 2.1.3            | Battery input diode                              | 14   |
|   |      | 2.1.4            | Battery input PI filter (R1, C2, C3)             | 15   |
|   |      | 2.1.5            | Energy reserve capacitor (C6)                    | 16   |
|   |      | 2.1.6            | Safing switch MOSFET                             | 19   |
| 3 | Pow  | er mode          | s                                                | . 22 |
|   | 3.1  | Power of         | off mode                                         | 23   |
|   | 3.2  | Sleep n          | node                                             | 23   |
|   | 3.3  | Active r         | mode                                             | 25   |
|   | 3.4  | Passive          | e mode                                           | 29   |
|   | 3.5  | Power r          | mode functions status                            | 32   |
| 4 | Ope  | ration. c        | ontrol & diagnostics                             | 33   |
|   | 4.1  | WDOG             | _                                                |      |
|   |      | 4.1.1            | Temporal watchdog initial - INIT STATE           |      |
|   |      | 4.1.2            | WD1 INITIAL- WD1 RESET                           |      |
|   |      | 4.1.3            | WD1 INITIAL - WD1 OVERRIDE                       | 38   |
|   |      | 4.1.4            | WD1 INITIAL - WD1 RUN                            | 39   |
|   |      | 4.1.5            | WD1 RUN - WD1 test                               | 41   |
|   |      | 4.1.6            | Algorithmic watchdog WD2                         | 42   |
|   |      | 4.1.7            | Algorithmic watchdog WD2 - WD2 INIT              | 43   |
|   |      | 4.1.8            | Algorithmic watchdog WD2 - INITSEED              | 44   |
|   |      | 4.1.9            | Algorithmic watchdog WD2 - WD2RUN                | 44   |
|   |      | 4.1.10           | Algorithmic watchdog WD2 - WD2QUAL               | 44   |
|   |      | 4.1.11           | Algorithmic watchdog WD2 - WD2LOCK               | 45   |
|   |      | 4.1.12           | Algorithmic watchdog WD2 - WD2STOPPING - WD2STOP | 45   |
|   |      |                  |                                                  |      |
|   |      | 4.1.13           | Algorithmic watchdog WD2 - WD2RESET - WD2INIT    | 45   |
|   |      | 4.1.13<br>4.1.14 | Algorithmic watchdog WD2 - WD2RESET - WD2INIT    |      |

|   |      | 4.1.15 Algorithm  | nic watchdog WD2 - WD2TEST4              | 6 |
|---|------|-------------------|------------------------------------------|---|
|   | 4.2  | ER CAP feature    | s 4                                      | 6 |
|   |      | 4.2.1 ESR me      | asurement4                               | 7 |
|   | 4.3  | ER CAP measur     | rement                                   | 0 |
| 5 | Armi | ng                |                                          | 3 |
|   | 5.1  | Internal safing e | ngine                                    | 3 |
|   | 5.2  | External safing e | engine 5                                 | 6 |
|   | 5.3  | Safing records    |                                          | 7 |
|   | 5.4  | SPI sensor data   | decoding (16 bit Safing record mask) 6   | 1 |
|   |      | 5.4.1 Request     | Mask (MOSI line)                         | 1 |
|   |      | 5.4.2 Request     | Target (MOSI line)                       | 2 |
|   |      | 5.4.3 Respons     | se Mask (MISO line)6                     | 3 |
|   |      | 5.4.4 Respons     | se Target (MISO line)                    | 4 |
|   |      | 5.4.5 Data Ma     | sk (MISO line)6                          | 5 |
|   | 5.5  | SPI sensor data   | decoding (32 bit safing record mask) 6   | 6 |
|   |      | 5.5.1 Request     | Mask (MOSI line)                         | 7 |
|   |      | •                 | Target (MOSI line)                       |   |
|   |      | •                 | se Mask (MISO line)                      |   |
|   |      | •                 | se Target (MISO line)                    |   |
|   |      |                   | sk (MISO line)                           |   |
|   | 5.6  | ,                 | crash sensor orientation                 |   |
|   |      | 5.6.1 Comb (0     | Combined Data)                           | 3 |
| 6 | Depl | yment             |                                          | 5 |
|   | 6.1  | Deployment req    | uirement                                 | 5 |
|   | 6.2  | Deployment driv   | er protection                            | 2 |
|   | 6.3  | Deployment driv   | er example 8.                            | 2 |
|   |      | 6.3.1 LOOP_N      | //ATRIX_ARMx:                            | 2 |
|   |      | 6.3.2 Deployn     | nent configuration channel8              | 3 |
| 7 | Whee | l speed sensoi    | interface (WSS)8                         | 9 |
|   | 7.1  | SPI configuration | า9                                       | 0 |
|   | 7.2  | Bench results - A | Allegro ATS682LSH STD sensor             | 0 |
|   | 7.3  | Bench results - A | Allegro ATS651LSH PWM sensor 9           | 1 |
|   | 7.4  | Bench results In  | fineon TLE4942, BOSCH DF11 PWM sensors 9 | 2 |
|   |      |                   |                                          |   |



| Contents |       |                                          | AN5023 |
|----------|-------|------------------------------------------|--------|
|          | 7.5   | Bench results Philips KMI22/1 VDA sensor | 94     |
| Appendix | k A E | Bill of materials                        | 96     |
| Revision | histo | ry                                       | 105    |

AN5023 List of tables

# List of tables

| <del>-</del> | AS A DOLATE OT A STATE                              |    |
|--------------|-----------------------------------------------------|----|
| Table 1.     | \$04 POWER_CTL_STATE                                |    |
| Table 2.     | \$03 SPI_SLEEP                                      |    |
| Table 3.     | \$01 SYS_CFG ERBOOST in ER state                    |    |
| Table 4.     | Functions DISABLED by Power Mode                    |    |
| Table 5.     | \$04 POWER_CTL_STATE                                |    |
| Table 6.     | \$2C WD_STATE                                       |    |
| Table 7.     | \$00 FAULT STATE                                    | 35 |
| Table 8.     | Watchdog WD1                                        |    |
| Table 9.     | WD_TEST                                             | 38 |
| Table 10.    | \$2B WD1T                                           | 39 |
| Table 11.    | \$35 WD TEST                                        | 41 |
| Table 12.    | \$2C WD STATE                                       |    |
| Table 13.    | \$00 FAULT STATE                                    |    |
| Table 14.    | \$33 WD2 SEED                                       |    |
| Table 15.    | \$32 WD2 RECOVER                                    |    |
| Table 16.    | \$35 WD TEST                                        |    |
| Table 17.    | \$04 SYS STATE                                      |    |
| Table 18.    | \$02 SYS CTL (1)                                    |    |
| Table 19.    | \$02 SYS_CTL (2)                                    |    |
| Table 19.    | \$38 LPDIAGREQ                                      |    |
| Table 20.    | ESR measurement                                     |    |
| Table 21.    | \$6E LOOP MATRIX ARM1                               |    |
|              |                                                     |    |
| Table 23.    | \$DF SAF_THRESHOLD_1                                |    |
| Table 24.    | \$66 SAF_ALGO_CONF                                  |    |
| Table 25.    | \$FF SAF_CC                                         |    |
| Table 26.    | \$6A ARM STATE                                      |    |
| Table 27.    | \$6E LOOP_MATRIX_ARM1                               |    |
| Table 28.    | \$EF÷FE SAF_CONTROL_x                               |    |
| Table 29.    | \$7F SAF_ENABLE                                     |    |
| Table 30.    | \$80 SAF_REQ_MASK_1                                 |    |
| Table 31.    | \$93 SAF_REQ_TARGET_1                               |    |
| Table 32.    | \$A6 SAF_RESP_MASK_1                                |    |
| Table 33.    | \$B9 SAF_RESP_TARGET_1                              |    |
| Table 34.    | \$CC SAF_DATA_MASK_1                                | 65 |
| Table 35.    | \$01 SYS_CFG                                        |    |
| Table 36.    | \$8D SAF_REQ_MASK_14_pt1                            |    |
| Table 37.    | \$A0 SAF_REQ_TARGET_14_pt1                          | 68 |
| Table 38.    | \$B3 SAF_RESP_MASK_14_pt1                           |    |
| Table 39.    | \$C6 SAF RESP TARGET 14 pt1                         | 70 |
| Table 40.    | \$D9 SAF_DATA_MASK_14_pt1                           | 72 |
| Table 41.    | \$06 DCR_0: \$11 DCR_B deploy parameters            | 75 |
| Table 42.    | \$13 DSR_0: \$1E DSR_B                              |    |
| Table 43.    | \$6E LOOP_MATR_ARM1: \$71 LOOP_MATR_ARM4            | 77 |
| Table 44.    | \$30 SCRAP state, \$31 SAFING state, \$04 SYS_STATE |    |
| Table 45.    | \$6A ARM STATE                                      |    |
| Table 46.    | \$25 SPIDEPEN                                       |    |
| Table 47.    | \$12 DEPDOM, \$25 SPIDEPEN                          |    |
| Table 48.    | \$13 DSR_0: \$1E DSR_B                              |    |
| . abio +0.   | Ψ · · · · · · · · · · · · · · · · · · ·             |    |



| ist of tables | AN5023 |
|---------------|--------|
|               | ANOUZ  |

| Table 49. | \$1F DCMTS_01 ÷ \$24 DCMTS_AB                | . 81 |
|-----------|----------------------------------------------|------|
| Table 50. | DEPOK in GSW                                 | . 81 |
| Table 51. | Example of SPI message to deploy             | . 83 |
| Table 52. | PWM1 pulse speed length measurement in RSDRx | . 91 |
| Table 53. | PWM2 pulse speed length measurement in RSDRx | . 93 |
| Table 54. | VDA message reading WSIRSDR [3:0]            | . 94 |
| Table 55. | Bill of materials                            | . 96 |
| Table 56. | Document revision history.                   | 105  |

AN5023 List of figures

# List of figures

| Figure 1.  | Device's voltage regulators                                                     | 9  |
|------------|---------------------------------------------------------------------------------|----|
| Figure 2.  | Device's loops                                                                  | 11 |
| Figure 3.  | Example of components positioning                                               |    |
| Figure 4.  | Example of active suppressor positioning (solution 1)                           | 13 |
| Figure 5.  | Example of active suppressor positioning (solution 2)                           | 14 |
| Figure 6.  | COVRACT - low battery management                                                | 14 |
| Figure 7.  | Protection circuit                                                              | 15 |
| Figure 8.  | Battery input filter                                                            |    |
| Figure 9.  | Blocks supplied through energy reserve capacitor                                | 16 |
| Figure 10. | Energy reserve capacitor discharge in autarchy mode                             |    |
| Figure 11. | Schematic example to perform SAFING FET test                                    | 20 |
| Figure 12. | Range values for VSF safing fet test                                            | 20 |
| Figure 13. | Operating modes                                                                 |    |
| Figure 14. | L9680 turn on, SLEEP MODE                                                       | 24 |
| Figure 15. | Wake up filter timing & operating mode                                          | 25 |
| Figure 16. | Normal power-up sequence with VCOREMON function disabled                        | 26 |
| Figure 17. | Normal power-up sequence with VCOREMON function enabled                         | 27 |
| Figure 18. | COVRACT in autarchy mode                                                        |    |
| Figure 19. | Supply of other devices in autarchy mode via COVRACT                            | 30 |
| Figure 20. | Device functionality                                                            | 33 |
| Figure 21. | WD1 functionality                                                               | 34 |
| Figure 22. | WATCHDOG initial                                                                |    |
| Figure 23. | WD1 INITIAL ↔ WD1 RESET                                                         |    |
| Figure 24. | WD1 INITIAL ↔ WD1 OVERRIDE                                                      | 38 |
| Figure 25. | WD1 INITIAL ↔ WD1 RUN ↔ WD1 RESET                                               | 39 |
| Figure 26. | WATCHDOG service                                                                |    |
| Figure 27. | WD2 functionality                                                               | 42 |
| Figure 28. | ESR measurement phases                                                          |    |
| Figure 29. | ESR measurement                                                                 |    |
| Figure 30. | ER CAP measurement                                                              | 51 |
| Figure 31. | C_ER measurement                                                                | 52 |
| Figure 32. | DWELL time                                                                      |    |
| Figure 33. | SPI signal and SAF_CS0÷SAF_CS3                                                  |    |
| Figure 34. | Sensor's axis and vehicle's axis correlation                                    |    |
| Figure 35. | Current measurement during deploy                                               |    |
| Figure 36. | Deployment loop example                                                         |    |
| Figure 37. | Wheel speed interface configuration                                             |    |
| Figure 38. | STD operation @ different speeds                                                |    |
| Figure 39. | Possible STD operation in standstill conditions                                 |    |
| Figure 40. | STD sensor: WSx re-engagement after standstill                                  |    |
| Figure 41. | PWM1 operation 45 µs and 90 µs pulse @fixed speed v = v1                        |    |
| Figure 42. | PWM1 operation in pass-through mode                                             |    |
| Figure 43. | PWM2 operation 45, 90, 180, 360 and 720 µs pulse @ fixed speed                  |    |
| Figure 44. | PWM2 operation in standstill with SSDIS bit disabled (left) and enabled (right) |    |
| Figure 45. | PWM2 operation in pass-through mode PWM2                                        |    |
| Figure 46. | VDA operation 8bit + P                                                          |    |
| Figure 47. | VDA operation @ high speed: 2bit message                                        |    |
| Figure 48. | VDA operation in standstill: 8bit + P message                                   | 95 |
|            |                                                                                 |    |



Detail features AN5023

# 1 Detail features

- Energy reserve voltage power supply ERBOOST
  - High frequency boost regulator, 1.875 MHz
  - Output voltage user selectable, 23 V or 33 V ±5%
  - Measurement of reserve capacitor value & ESR diagnostics
- Output voltage regulator power supply for PSI-5 SYNC pulse SYNCBOOST
  - High frequency boost regulator, 1.875 MHz
  - Output voltage user selectable, 12 V/14.75 V ±5%
- Output voltage regulator power supply for remote sensor SATBCK
  - High frequency buck converter, 1.875 MHz
  - Output voltage user selectable, 7.2 V/9 V ±4%
- Output voltage regulator power supply for linear and logic VCC
  - High frequency buck converter, 1.875 MHz
  - Output voltage user selectable, 3.3 V or 5.0 V ±4%
- Integrated crossover switch
  - Crossover performance 3 Ω 980 mA max
  - Switch active output indicator (COVRACT pin)
- Battery voltage monitor & shutdown control with Wake-up control
- System voltage diagnostics with integrated ADC
- Squib deployment drivers
  - 12 channel HSD/LSD
  - 25 V max deployment voltage
  - Various deployment profiles, 1.2 A/1.75 A, x\*0.064 ms up to 4.032 ms
  - Current monitoring
  - Rmeasure, STB, STG & Leakage diagnostics
  - High & low side driver FET tests
  - Safing FET test
- High side safing switch regulator and enable control
- Four channels remote sensor interface for PSI-5 (synchronous mode) or active wheel speed sensors
- Three channels GPO, HSD or LSD configurable, with PWM 0-100% control
- Nine channels Hall-effect, resistive or switch sensor interface
- User customizable safing logic
- Specific disarm signal for passenger airbag
- Temporal and Algorithmic Watchdog timers
- End of life disposal interface
- Temperature sensor
- 32 bit SPI communications
- Minimum operating voltage = 5.5V at device battery pin
- Operating temperature, -40 °C to 95 °C
- Packaging 100 pin

8/106

# 2 Device mechanization overview

ERBSTSW VER VSF ER ER Charge / Discharge and ER CAP Diag ER Switch VBAT\_MON Battery VIN IGN WAKEUP VINT3V3 CVDD VDD Regulator Regulato **GNDSUB**x SYNCBSTSW SYNC BOOST Oscillator s GNDD **BSTGND** SYNCBOOST L9680 SATBCKSW SATGND SATBCK VCCBCKSW VCCSEL Output RESET GNDSUBx (\*) Capacitor on ERBOOST can be selected smaller in case ERBOOST is set to remain ON also in Autarchy mode (ER STATE). This selection is chosen setting b[12] = Keep\_ERBoost\_ON in \$01 SYS\_CFG (INIT). Recommended value is 2.2μF (1μF min) low ESR, otherwise its value is higher, 100μF-200uF low ESR. GAPGPS03089

Figure 1. Device's voltage regulators



# 2.1 External components summary

The ASD551C has been designed in order to be compatible with all the ASIC of the family, ie L9678, L9679 and L9680. It is possible either to solder the ASIC or mount a socket adapter.

The board has been designed in order to provide the means to host an external microcontroller daughter-board.

Most external components are standard design practice devices, such as filter capacitors. The user selectable components typically are determined by system requirements or operating profiles. The following sections outline analysis to derive some key system components.

See Bill of materials on page 96.

# 2.1.1 Component layout considerations

Placement of the component's regulators on the layout has to be evaluated with care, focusing on the regulation loops that have to be optimized from area point of view. Loops that have to be managed with care are highlighted in different colors, one per loop, the other components, left in black, can be located on the board with no particular restrictions.

Two loops related to BSTGND:

- 1. Loop 1: D1 and C7 must be placed in order to minimize the loop area between ERBSTSW (pin 84) and BSTGND (pin 85)
- 2. Loop 2: D12 and C85\_1 must be placed in order to minimize the loop area between SYNCBOOSTSW (pin 86) and BSTGND (pin 85)

Two loops related to SATGND:

- 1. Loop 3: C81 must be placed in order to minimize the loop area between SYNCBOOST (pin 87) and SATGND (pin 89)
- Loop 4: C2\_1 must be placed in order to minimize the loop area between SATBCK (pin 90) and SATGND (pin89); loop area minimization is relevant but less relevant respect to loop 3

Three loops related to VCCGND:

- Loop 5: C82 must be placed in order to minimize the loop area between SATBCK (pin 90) and VCCGND (pin 92)
- Loop 6: C86\_1 must be placed in order to minimize the loop area between VCC (pin 95) and VCCGND (pin 92); loop area minimization is relevant but less relevant respect to loops 5 and 7
- 3. Loop 7: C83 must be placed in order to minimize the loop area between VCC (pin 95) and VCCGND (pin 92)

One loop related to GNDD:

1. Loop 8: C23 must be placed in order to minimize the loop area between CVDD (pin 93) and GNDD (pin 94)

10/106 DocID030428 Rev 1





Figure 2. Device's loops

Referring to the regulation loops, an example of the components' disposition is:

D12

Figure 3. Example of components positioning



GAPGPS03091

## 2.1.2 ESD and SPIKE protection

To protect against ESD stress, a low impedance path to ground must exist through the device.

An effective approach for protecting any electronic system against ESD is to mechanically minimize the path ways by which high voltages enter the system from the outside environment.

Using external components, a common method to protect the IC from ESD events is to add a small serial resistor in-line between the ESD energy source and the device pin to be protected.

This method improves the ESD system robustness for two reasons:

- The resistor's parasitic capacitor (typically in the range of 5 pF to 10 pF) slows the events
- 2. The resistor, in combination with the internal pin impedance, forms a voltage divider so that only a part of the high ESD voltage reaches the pin itself

In case of input/output lines that are susceptible to ESD it is suggested to add an external active component, TVS (transient voltage suppression) or Zener diode, which shunts the high energy of the ESD stress before it can reach the device pin.

The following examples are aimed at optimizing ESD protection device placement and the PCB layout to reach the best ESD performance possible.



Figure 4. Example of active suppressor positioning (solution 1)

It is here highlighted the parasitic inductance influence of the PCB track with respect to the insertion of an active suppressor, T1. An ESD event shows a rise time within 1 ns, attaching importance to the track parasitic inductances named L1 and L2 in the picture.

As an example, let's consider L1 and L2 the parasitic inductance associated to the two tracks named L1 and L2 in *Figure 4*, estimate 1nH/mm their specific inductance and di/dt = 20 A/ns. Voltage at pin is so determined:

$$V_{CL} + (L_1 + L_2) * \frac{di}{dt} =$$

$$= V_{CL} + (10 + 5)nH * 20 \frac{A}{ns} =$$

$$= V_{CL} + 300 V$$

GAPGPS03093

Where V<sub>Cl</sub> is the clamp voltage of the T1.





Figure 5. Example of active suppressor positioning (solution 2)

This solution reduces considerably the parasitic inductance of the track interposed between the ESD source and the point to be protected.

In this case the value of L1 and L2 is strongly reduced and the resulting spike at the pin is closer to  $V_{\text{Cl}}$  .

## 2.1.3 Battery input diode

The system has been designed to support a reverse diode protection.

In case of very low voltage operation, in order to reduce the drop across this diode, the device provides the means to implement an active reverse protection, as showed below.

During normal operation, being COVRACT signal not asserted, T1 and T2 are kept OFF and PMOS Q1 is ON (VSG(Q1)~VBAT), showing at its terminals its Rdson which minimizes the voltage drop from battery.

When the IC moves in autarchy mode, COVRACT signal is asserted, Q1 is switched OFF and its intrinsic diode decouples VBAT from VIN;

Vin is connected through crossover switch at the external reserve capacitor.



Figure 6. COVRACT - low battery management

577

VBATMON pin is designed to be connected before the reverse protection diode, so far it is able to sustain down to -18 V.

For the applications which require to survive at a deeper under-voltage, the pin is designed to sustain 20 mA max reverse current. To limit the current in VBATMON pin it is possible to insert a series resistor. Its value is defined as shown below:

Figure 7. Protection circuit



$$I(VABATMON) = \frac{|Vmin - (-18V)|}{R} \le 20mA$$

$$R \ge \frac{|Vmin + 18V|}{20mA}$$

# 2.1.4 Battery input PI filter (R1, C2, C3)

Battery current is influenced primarily by the energy reserve boost regulator operation. The boost clock frequency is nominally 1.875 MHz. The filter 3 dB corner frequency is set to 200 kHz. To reduce R1 voltage drop and power dissipation, the value is kept low while also allowing reasonable C2 & C3 component values. All components can be adjusted as necessary for the application.



Figure 8. Battery input filter



GADG1503171530PS

# 2.1.5 Energy reserve capacitor (C6)

Energy reserve capacitor stores the necessary energy to operate the Airbag ECU during loss of battery. System operating requirements influence the device selection and calculations. The following example makes general operating assumptions and changing the assumptions may effect calculations and results.

During loss of battery operation, energy reserve operation can be mechanized as shown. To continue the analysis, system functional operating assumptions must be determined. These assumptions are shown in the drawing below. Operation assumes three states, sensing, deploy and shutdown. During sensing state, all functions operate normally. In deploy state, all functions remain operational and all squib deployment channels are fired. The final state, shutdown, reduces operation to the microcontroller only.



Figure 9. Blocks supplied through energy reserve capacitor

16/106 DocID030428 Rev 1



Figure 10. Energy reserve capacitor discharge in autarchy mode

At t = T0 = 0,  $V_0 = V_{ER} - I_{SYS} \cdot (R_{ESR} + R_{CO})$ 

Where:

 $V_{ER}$  = Energy reserve voltage just prior to loss of battery detection and crossover operation  $I_{SYS}$  = System current consumption, L96xx bias, Voltage regulators, RSUs, DC Sensors  $R_{ESR}$  = Energy capacitor's ESR

R<sub>CO</sub> = Crossover Switch Resistance

$$I_{SYS} = C * \left( \frac{V_0 - V_1}{T_1 - T_0} \right)$$

GAPGPS03005

$$V_1 = V_0 - \frac{I_{SYS} * (T_1 - T_0)}{C}$$

GAPGPS03006

**Equation 1** 

$$V1 = V_{ER} - I_{SYS}^* (R_{ESR} + R_{CO}) - \frac{I_{SYS}^* T_1}{C}$$

GAPGPS03007

Deployment begins at T1, thus increasing energy reserve current and effects due to ESR

**Equation 2**  $V2 = V1 - I_{DEPLOY} \cdot R_{ESR}$ 

Where  $I_{DEPLOY}$  = total deployment current controlled by L96xx



Substituting (1) into (2):

#### Equation 3

$$V2 = V_{ER} - I_{SYS}^* (R_{ESR} + R_{CO}) - \frac{I_{SYS}^* T_1}{C} - I_{DEPLOY}^* R_{ESR}$$

GAPGPS03008

During deployment phase, reserve voltage behavior is characterized as:

$$I_{SYS} + I_{DEPLOY} = C * \frac{V2 - V3}{T2 - T1}$$

GAPGPS03009

#### **Equation 4**

$$V3 = V2 - \frac{T_{DEPLOY} * (I_{SYS} + I_{DEPLOY})}{C}$$

GAPGPS03010

Substituting (3) into (4):

$$V3 = (V_{ER} - I_{SYS} * (R_{ESR} + R_{CO}) - \frac{I_{SYS} * T_{1}}{C} - I_{DEPLOY} * R_{ESR}) - \frac{T_{DEPLOY} * (I_{SYS} + I_{DEPLOY})}{C}$$

Once deployment is complete, the airbag module enters its final state, shutdown. Reserve current is reduced causing reserve voltage to increase due to a minor loss in capacitor CER and Cross over switch. The change in reserve voltage is calculated as:

#### **Equation 5**

$$V4 = V3 + I_{DEPLOY} * R_{ESR} + (I_{DCSENSOR} + I_{RSU}) * (R_{ESR} + R_{CO})$$
GAPCEPS 1301

#### **Equation 6**

$$V4 = (V_{ER} - I_{SYS} * (R_{ESR} + R_{CO}) - \frac{(I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{C} + \frac{(I_{SYS} * T_1 + I_{SYS} * T_1 + I_{SYS} * T_1 + I_{SYS} * T_1 + I_{SYS} * T_1 + I_{DEPLOY} * T_1 + I_{$$

In the equation (5) above, the system disables current to all deployment drivers, DC sensor and Remote Sensor Interfaces.

During shutdown phase, only Voltage regulator and device (L96xx) bias current are needed from reserve.

To complete energy reserve capacitor estimate, the analysis must assume a final reserve voltage requirement. In the study, energy reserve must be higher than VDDx dropout voltage where VDDx is the supply of the microcontroller.

By assuming this requirement, the system is designed to operate for the desired reserve time.

#### Equation 7 $V5 > VDDx_{DROPOUT}$

Reserve voltage behavior is as follows:

#### **Equation 8**

$$I_{SHUTDOWN} = C * \frac{V4 - V5}{T3 - T2}$$

GAPGPS03014

Where

 $I_{SHUTDOWN} = I_{VDD} + I_{BIAS}$ 

Re-arranging (8)

 $I_{SHUTDOWN} \cdot (T_3 - T_2) C \cdot V4 - V5)$ 

Substituting (6) and (7):

$$I_{\text{SHUTDOWN}} * (T_3 - T_2) = C * ((V_{\text{ER}} - I_{\text{SYS}} * (R_{\text{ESR}} + R_{\text{CO}}) - \frac{(I_{\text{SYS}} * T_1 + I_{\text{SYS}} * T_{\text{DEPLOY}} + I_{\text{DEPLOY}} * T_{\text{DEPLOY}})}{C} + I_{\text{DEPLOY}} * R_{\text{ESR}} + I_{\text{DEPLOY}} * R_{\text{ESR}} + (I_{\text{DCSENSOR}} + I_{\text{RSU}}) * (R_{\text{ESR}} + R_{\text{CO}}) - VDDx_{\text{DROPOUT}})$$

Simplify and arrange

$$C = \frac{I_{SHUTDOWN} * (T_3 - T_2) + (I_{SYS} * T_1 + I_{SYS} * T_{DEPLOY} + I_{DEPLOY} * T_{DEPLOY})}{V_{ER} - I_{SYS} * (R_{ESR} + R_{CO}) + (I_{DCSENSOR} + I_{RSU}) * (R_{ESR} + R_{CO}) - VDDx_{DROPOUT}}$$
GAPGPS0301

# 2.1.6 Safing switch MOSFET

Safing switch provides two functions, fail-safe strategy and reducing energy absorbed by the high side deployment driver.

As fail-safe strategy, common practice is to have two independent and independently controlled components within the deployment path. This is often achieved by using a safing switch controlled by the microcontroller with an independent deployment driver IC.

For energy reduction, the L9680 is capable of deploying at a maximum voltage of 25 V. This can be done using the safing switch to absorb the excessive power or by setting VER to 23 V.

It is possible to measure via ADC the VSF and SSxy voltage, paying attention to the fact that as VSF is turned ON (SPI command) the external safing FET turns ON too.

The schematic proposed here represents a possible solution to perform SAFING FET test, which requires to have previously charged the external reserve capacitor, CER.

The solution requires an external network, two commands from the microcontroller, UC\_DEPEN and UC\_DIAGEN and the SSxy voltage measurement via ADC.

Depending on the status of VSF (ON or OFF) and on the commands from the microcontroller, three cases can occur as below described.



Figure 11. Schematic example to perform SAFING FET test

Figure 12. Range values for VSF safing fet test



In the **first case** of this *Figure 12*, external FET is working in voltage regulator mode (VSF ON, UC\_DEPEN, UC\_DIAGEN set);

voltage on SSxy pin is:

$$V_{SS_{xy}} = VSF - V_{CE_{SAT}} - V_{DIODE} - V_{GS} - V_{DIODE}$$

GAPGPS02928

The expected value read on ADC, depending on all the parameter variations, is in the range of  $10\ V$  to  $22\ V$ .

57

20/106 DocID030428 Rev 1

In the **second case** the low side command of the diagnostic is enabled and voltage on SSxy pin is:

$$V_{SS_{xy}} = 100 \frac{VER - V_{CE_{SAT}}}{100 + 360} + V_{CE_{SAT}} - V_{DIODE}$$

GAPGPS02929

The expected value read on ADC, depending on all the parameter variations, is in the range of 4V to 7V.

In the **third case** everything is disabled so the voltage on SSxy is expected to be close to VER:

$$V_{SS_{xy}} \approx VER - V_{DIODE}$$
GAPGPS02930

Any SSxy read via ADC, out of the expected range has to be considered as a faulty condition.

Note:

Once UC\_DIAGEN is active, capacitors on SSxy pins are discharged through 4.7 k $\Omega$  which requires about 1 ms to reach a steady state, so a proper time should elapse before running the ADC conversion.

Besides, in order to guarantee better safety, it is possible to read the voltage on VDEPLOY net through a voltage divider which is sensed by the ADC of the microcontroller.

The solution presented can be used when the ARMING is based on internal safing engine in order to guarantee redundancy; parallel path IC independent is needed to enable safing FET.

In case the ARMING algorithm is run by the microcontroller, the circuit which turns ON the safing FET can be removed (both MUN5332DW1 and D5 diode): VSF can be connected directly to the FET gate and UC\_DEPEN can be used to drive FENH and FENL or their equivalent.



Power modes AN5023

# 3 Power modes

The state diagram shown below defines L9680 power mode progression.

There are four specific power modes: Power-Off, Sleep, Active and Passive.

Figure 13. Operating modes



AN5023 **Power modes** 

Power mode status can be read through SYS STATE register.

(1) (2) 16 15 14 13 12 11 10 9 8 7 6 5 4 19 18 17 3 2 0 POWER CTL STATE STATE b[2:0]] **OPER CTL STATE** 000 = AWAKE 001 = START UP CTL R 010 = RUN 011 = ER **OWER** 100 = POWER SHUT-DOWN

Table 1. \$04 POWER CTL STATE

**\$04** 

#### 3.1 Power off mode

In Power Off mode, the device is in reset, all power supplies are disabled.

As soon as the voltage on WAKEUP pin rises over WU mon, the device starts the power-up process, passing in Sleep Mode.

101, 110, 111 unused

It will turn back in POWER OFF mode from PASSIVE due to a specific SPI command combined with adequate WAKEUP condition or power on reset, POR, due to battery lost.

#### 3.2 Sleep mode

The IC enters in SLEEP MODE

- during the device's turn on as WAKEUP>WU\_mon
- 2. from ACTIVE MODE (before 9 ms filter time has expired on WAKEUP pin), as WAKEUP turns low or VIN<VINBAD
- during its turn off from POWER SHUTDOWN mode as VIN<VINGOOD

Typical mechanizations for electrically configuring wake-up are shown in *Figure 14*.

These are typical mechanizations and do not show detailed descriptions for all connections and external components.

R = READ W = WRITE.

Power modes AN5023



Figure 14. L9680 turn on, SLEEP MODE

Once passed in SLEEP MODE, the internal regulators, 3V3INT & CVDD (only CVDD is accessible on pin 93), are turned on and the IC is ready for the activation of all the other supplies.

Supposing the IC supplied, see as example *Figure 15*, through VIN and VBAT\_MON (that is the supply monitor) the IC's turn on depends on WAKE\_UP, that can be connected to the external power supply (cases "a" and "b") or can be driven by the microcontroller (case "c").

As WAKE\_UP is high, it is necessary that its value should be constantly high for at least WakeUpFil time otherwise the turn on procedure restarts from the case of WAKE\_UP pin low and the IC remains in SLEEP MODE. See *Figure 14* for WAKE\_UP timing management.

57/

AN5023 Power modes

#### Once:

(WakeUpFil=1) AND (VIN > VINGOOD) the device moves in ACTIVE MODE.



Figure 15. Wake up filter timing & operating mode

For value of relevant parameters, refer to the device specification.

VBGOOD, VBBAD, VINGOOD & VINBAD thresholds are programmable using the SYS\_CTL register. However, this cannot be done until the device reaches ACTIVE mode, therefore the device must be initially powered at the default values.

### 3.3 Active mode

As stated in the previous section, the device enters Active Mode once the following conditions are met:

- WakeUpFil=1; WAKEUP high for filter time
- VIN > VINGOOD

While in ACTIVE Mode and Twakeup timing has not expired, the device is in the STARTUP state. In STARTUP, it is possible to return back to SLEEP Mode should any of the conditions shown above fail.

Once WAKEUP is asserted for longer than Twakeup, the device starts normal operation, RUN State. In RUN state, all supplies are enabled and RESET is released upon reaching regulation. A possible topology of serial communications wake-up is shown in *Figure 16* and 17.

In RUN state, the IC cannot directly return to the previous states, either the STARTUP or SLEEP mode. The device can only move to PASSIVE mode or remain in RUN state.

While in RUN state, normal ECU operation starts. The microcontroller can start programming, controlling and monitoring system functions through the L9680 device. Details on programming, controlling and monitoring system functions will be covered in the System Operating States section.

Power modes AN5023



Figure 16. Normal power-up sequence with VCOREMON function disabled



AN5023 Power modes



Figure 17. Normal power-up sequence with VCOREMON function enabled



Power modes AN5023

Note:

In case of VCCSEL open pin, an internal pull down current would force VCCSEL to ground and then the VCORE monitor will be enabled function.

If the VCORE voltage is low and the VCCSEL pin is higher than VTH1\_L\_VCCSEL, after the 4ms delay from power-up, a latched VCOREMON fault will cause RESET output to drive low, even though VCCSEL pin is high enough to satisfy the disabling of VCOREMON function. This occurs only once at power-up, and is then appropriately disabled. For this reason the RESET is released 500us (namely the reset\_hold\_time) after the 4ms delay from power-up.

Different RESET behavior depending on VCORE monitor status are reported in Figure 16 and 17.

Note:

There are two thresholds for VIN GOOD and VINBAD, VINGOOD0 / VINBAD0 & VINGOOD1 / VINBAD1.

At power up, the default values are VINGOOD0 / VINBAD0.

Once WAKEUP has been correctly managed up (see *Section 3.2: Sleep mode*) as VIN>VINGOOD0 the IC moves in ACTIVE MODE.

Let's consider the situation where in STARTUP the microcontroller sets via SPI the thresholds VINGOOD1 / VINBAD1.

Let's also consider to be in a condition where

#### VINGOOD0 < VIN < VINBAD1

VIN < VINBAD1 in STARTUP state determines the IC to turn back in SLEEP mode (AWAKE state) and the SPI configurations to be reset at the default value.

So far, once back in SLEEP mode (AWAKE state) VIN > VINGOOD0 determines the IC to move again in STARTUP (active MODE). Microcontroller re-starts the programming and sets again VINGOOD1 / VINBAD1 threshold.

Then, being VIN < VINBAD1, the IC turns back in SLEEP mode (AWAKE state).

On the other hand, let's consider the case where the IC is already in RUN state the microcontroller sets via SPI the thresholds VINGOOD1 / VINBAD1.

Let's also consider to be in a condition where

VINGOOD0 < VIN < VINBAD1

VIN < VINBAD1 in RUN state determines the IC to move into autarchy mode (PASSIVE MODE, ER state).

AN5023 Power modes

## 3.4 Passive mode

PASSIVE mode can only be entered from ACTIVE mode, RUN state. There are two states within PASSIVE mode, ER state (autarchy) and SHUTDOWN state.

There are two scenarios for transitioning to PASSIVE mode:

- Scenario 1: WakeUpFlt = 0 & SPI\_SLEEP command → SHUTDOWN state
- Scenario 2: VIN < VINGOOD → ER state</li>

**Scenario 1** corresponds to a driven shutdown via microcontroller which drives the WAKEUP pin low for at least 1 msec and sends a specific SPI sleep command:

Table 2. \$03 SPI\_SLEEP

|                | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|-----|-----|----|----|----|----|----|----|----|----|----|----|---|------|-----|---|---|---|---|---|---|---|
| \$03 SPI_SLEEP | -   | W   | -  | 1  | 1  | ı  |    |    |    |    |    |    |   | \$30 | C95 |   |   |   |   |   |   |   |

- 1. I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.

**Scenario 2** represents the case low or loss of battery voltage - autarchy mode.

When VIN < VINGOOD the IC moves in PASSIVE MODE - ER state and COVRACT signal is asserted.

An example of COVRACT behavior in autarchy mode is reported in *Figure 18*, where ch1 = RESET, ch2 = COVRACT, ch3 = VIN, ch4 = VER.

Figure 18. COVRACT in autarchy mode



COVRACT signal can be employed in case other ICs and/or satellite receivers have to be supplied during autarchy mode.

Being ER SWITCH current limited, a supplementary cross over switch may be needed and the simplified external circuitry to be used is shown in *Figure 19*.

Power modes AN5023



Figure 19. Supply of other devices in autarchy mode via COVRACT

The difference between options A and B is just the current that flows through the diode (active or passive) placed between battery line (VBAT) and VIN pin.

If the current consumption of additional ASICs is too high to permit the IC to work at low battery level, the option A is mandatory, otherwise option B is suited too.

In autarchy mode the energy requirement, which may include the firing too, is taken from the external reserve capacitor, up to the capacitor is depleted and reset happens. In this condition, current from the external reserve capacitor is limited by "ER switch" (refer to the spec for the values), regardless VER value (22 V or 33 V). The external reserve capacitor has to be chosen taking into account the highest energy requirement.

If the capacitor on VER pin is not fully charged and VIN goes low, the external reserve capacitor could not be able to supply the system with the energy required.

In autarchy mode "ER charge" is disabled to decouple ERBOOST from VER.

ERBOOST in autarchy mode can remain enabled or can be disabled basing on the configuration of bit[12] KEEP ERBST ON in \$01 SYS CFG register:

4

AN5023 Power modes

#### Table 3. \$01 SYS\_CFG ERBOOST in ER state

|              | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12            | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                                                                       |
|--------------|-----|-----|----|----|----|----|----|----|----|---------------|----|----|---|---|---|---|---|---|---|---|---|---|---------------------------------------------------------------------------------------|
| \$01 SYS_CFG | ı   | w   | -  | -  | -  | -  |    |    |    | KEEP_ERBST_ON |    |    |   |   |   |   |   |   |   |   |   |   | 12:<br>0=ERBOOST<br>disabled<br>in ER state<br>1= ERBOOST stay<br>enabled in ER state |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

Once in autarchy mode, the IC turns back in RUN state if VBATmon > VBGOOD condition is satisfied that implies the battery voltage recovered from a low voltage or dropout condition and hence normal operation can resume.

If the condition is not satisfied, shutdown can occur for the depletion of energy reserve (reset) or through a driven shutdown via SPI command. In this case the microcontroller completes all necessary "housekeeping" tasks, disables the WAKEUP input and sends the SPI SLEEP command reaching SHUTDOWN MODE.

Once in SHUTDOWN MODE, the IC can:

- turn back in ACTIVE MODE if VIN turns at its correct level and WAKEUP is correctly managed
- 2. move to POWER OFF if microcontroller sends SPI\_OFF command and VIN is enough to keep the IC out of RESET, otherwise a POR happens.

<sup>2.</sup> R = READ W = WRITE.

Power modes AN5023

# 3.5 Power mode functions status

Various functions are enabled and disabled within the power mode operating state machine. A summary of functions DISABLED in each operating mode is shown in *Table 4*.

**Table 4. Functions DISABLED by Power Mode** 

|                          | Power<br>Off | Wakeup<br>Monitor | Awake    | Startup | Run | Power mode<br>Shutdown | ER       |
|--------------------------|--------------|-------------------|----------|---------|-----|------------------------|----------|
| Wakeup Detector          | 1            |                   |          |         |     |                        |          |
| Internal Regulators      | <b>V</b>     | <b>V</b>          |          |         |     |                        |          |
| ERBOOST Regulator        | <b>V</b>     | √                 | <b>V</b> |         |     | √                      | √        |
| SYNCBOOST Regulator      | <b>V</b>     | <b>V</b>          | √        |         |     |                        |          |
| ER CAP Charge Current    | <b>V</b>     | <b>V</b>          | √        |         |     | √                      | <b>V</b> |
| ER switch                | <b>V</b>     | √                 | √        | 1       | √   |                        |          |
| SATBUCK Regulator        | <b>V</b>     | √                 | √        |         |     |                        |          |
| VCC Regulator            | <b>V</b>     | <b>V</b>          | √        |         |     |                        |          |
| Deployment Drivers       | <b>V</b>     | √                 | <b>V</b> |         |     |                        |          |
| VSF Safing FET regulator | <b>V</b>     | <b>V</b>          | √        |         |     |                        |          |
| Remote Sensor Interfaces | <b>V</b>     | √                 | <b>V</b> |         |     |                        |          |
| Watchdog                 | <b>V</b>     | √                 | <b>V</b> |         |     |                        |          |
| Diagnostics              | <b>V</b>     | <b>V</b>          | √        |         |     |                        |          |
| DC Sensor Interface      | <b>V</b>     | √                 | <b>V</b> |         |     |                        |          |
| GPO drivers              | <b>V</b>     | √                 | <b>V</b> |         |     |                        |          |
| Safing Logic             | <b>V</b>     | <b>V</b>          | √        |         |     |                        |          |

# 4 Operation, control & diagnostics

Normal operation occurs when the device is in the ACTIVE power mode, particularly in the RUN state.



Figure 20. Device functionality

During power up phase, as RESET is de-asserted (IC in ACTIVE MODE), microcontroller starts working. In ACTIVE MODE are distinguishable five states, see *Figure 20*:

INITIALIZATION / DIAGNOSTIC / SAFING / SCRAP / ARMING

Each IC' state is readable via SPI:

Table 5. \$04 POWER\_CTL\_STATE

|                      | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9              | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1               | 0 |                                                                                                            |
|----------------------|-----|-----|----|----|----|----|----|----|----|----|----|----|----------------|---|---|---|---|---|---|---|-----------------|---|------------------------------------------------------------------------------------------------------------|
| \$04 POWER_CTL_STATE | -   | R   |    |    |    |    |    |    |    |    |    |    | OPER_CTL_STATE |   |   |   |   |   |   |   | POWER_CTL_STATE |   | b[10:8]<br>000 = INIT<br>001 = DIAG<br>010 = SAFING<br>011 = SCRAP<br>100 = ARMING<br>101, 110, 111 unused |

- 1. I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.



#### 4.1 **WDOG**

In INITIALIZATION state, several configuration parameters are managed, including watchdog settings.

The IC is equipped with two kinds of watchdog, time window (WD1) and algorithmic seed/key (WD2).

#### Temporal watchdog initial - INIT STATE 4.1.1



Watchdog status is readable via SPI:

Table 6. \$2C WD\_STATE

|               | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13   | 12 | 11 | 10 | 9         | 8 | 7 | 6           | 5            | 4 | 3 | 2         | 1         | 0 |         |                                                                                                                                                                                                                                        |
|---------------|-----|-----|----|----|----|----|----|----|------|----|----|----|-----------|---|---|-------------|--------------|---|---|-----------|-----------|---|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| \$2C WD_STATE |     | R   |    |    |    |    |    |    | 7 CW |    |    | ı  | WD1_STATE |   |   | WD2 FBR CNT | ,'<br>;<br>[ |   |   | THAT OCUM | WDZ_SIAIE |   | b[10:8] | 000 = INITIAL<br>001 = RUN<br>010 = TEST<br>011 = RESET<br>100 = OVERRIDE<br>0000 = INITIAL<br>0001 = OVERRIDE<br>0010 = INITSEED<br>0011 = RUN<br>0100 = TEST<br>0101= QUAL<br>0110=LOCK<br>0111= STOPPING<br>1000=STOP<br>1001=RESET |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / -= ALL STATES(I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

Watchdog faults are readable via SPI in \$00 FLTSR register:

Table 7. \$00 FAULT STATE

|            | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14    | 13     | 12    | 11   | 10     | 9      | 8 | 7 | 6      | 5 | 4 | 3 | 2 | 1 | 0 |                                                                                                            |
|------------|-----|-----|----|----|----|----|----|-------|--------|-------|------|--------|--------|---|---|--------|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------|
| \$00 FLTSR | -   | R   |    |    |    |    | WE | )2 re | etry ( | ont [ | 3:0] | WD2_LO | WD2_TM | > | 7 | WD1 TM | > |   |   |   |   |   | b[10:8]<br>000 = INIT<br>001 = DIAG<br>010 = SAFING<br>011 = SCRAP<br>100 = ARMING<br>101, 110, 111 unused |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

As WSM is released, watchdog is in its initial state, WD1 INITIAL.

In this phase it is possible to define all WD1 parameters, through \$2A WDTCR and \$28 WD\_RETRY\_CONF; as soon as the IC leaves WD1\_INITIAL and reaches DIAGNOSTIC state (that means WD1, WD2 run or OVERRIDE, see *Figure 21*), WD1 parameters can't be modified any more.



<sup>2.</sup> R = READ W = WRITE.

<sup>2.</sup> R = READ W = WRITE.

#### Table 8. Watchdog WD1

|                    | (1) | (2)                                   | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12         | 11   | 10                                                                     | 9 | 8 | 7             | 6 | 5 | 4 | 3 | 2 | 1            | 0        |                                                                               |                                                                           |
|--------------------|-----|---------------------------------------|----|----|----|----|----|----|----|------------|------|------------------------------------------------------------------------|---|---|---------------|---|---|---|---|---|--------------|----------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| ~                  | ~   |                                       |    |    |    |    |    |    |    |            |      |                                                                        |   |   | WDTDELTA[6:0] |   |   |   |   |   |              | 14:      | 0= fast WD1 8us<br>resolute, 2ms max<br>1== slow WD1 64µs<br>resolute, 16.3ms |                                                                           |
| \$2A WDTCR         | I   | W   -   -   -   X   MOM   WDTMIN[6:0] |    |    |    |    |    |    |    |            | 13:7 | WD1 min time<br>window. \$32 =<br>400µs; in fast mode,<br>see WD1_MODE |   |   |               |   |   |   |   |   |              |          |                                                                               |                                                                           |
|                    |     |                                       |    |    |    |    |    |    |    |            |      |                                                                        |   |   |               |   |   |   |   |   |              |          | 6:0                                                                           | WDTMAX=WDTMIN<br>+WDTDELTA; \$19 =<br>200µs in fast mode,<br>see WD1_MODE |
| \$28 WD_RETRY_CONF |     | W                                     | -  | -  | 1  | -  |    |    |    | WD2_ERR_TH |      | WD2_RETRY_TH                                                           |   |   |               |   |   |   |   |   | WD1_RETRY_TH |          | 2:0                                                                           | number of permitted<br>error before latching<br>WD1_LOCKOUT=1             |
| \$01 SYS_CFG       | I   | W                                     | -  | ı  | -  | -  |    |    |    |            |      |                                                                        |   |   |               |   |   |   |   |   |              | WD1_TOVR |                                                                               | _TOVR:<br>0ms timeout active<br>0ms timeout disabled                      |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

2. R = READ W = WRITE.

In WD1 INITIAL state all arming signals are disabled to prevent deployment. As soon as entered in WD1 INITIAL, a 500 ms time window counter is started.

Before such a 500 ms time counter expires, all watchdog parameters should be fixed and the WD1\_INITIAL should be left, a reset of the microcontroller will occur otherwise.

In order to disable the 500 ms counter and avoid reset generation, it is possible to set the bit WD1\_TOVR (see *Table 8*).

577

Figure 22. WATCHDOG initial



Note:

Disabling initial RESET toggling does not depend on the state of WDT/TM pin: SPI command is effective even if WDT/TM is grounded.

Each time the watchdog service routine fails, a counter is incremented; if the error counter reaches a programmable threshold (WD1\_RETRY\_TH) deployment is no more allowed (wd1\_lockout = 1).

It is also possible by means of a combination of a high voltage level on pin WDT\_DIS/TM and a proper SPI frame to completely disable watchdog and join DIAG state without any watchdog servicing.

In the following paragraphs a detailed description of the different watchdog phases is shown.

## 4.1.2 WD1 INITIAL- WD1 RESET

WD2\_SSMRST OR MCU\_SSMRST WSM reset (from any state)/ (from any state) / WD1\_LOCKOUT=1 WD1\_WDR=0 WD1 ERR CNT=0 WD1\_ERR\_TH\_WE=1 1ms / WD1 INITIAL WD1\_WDR=1 500ms AND WD1\_TOVR=0 / WD1\_LOCKOUT=1 WD1\_ERR\_CNT++ WD1 RESET GAPGPS03108

Figure 23. WD1 INITIAL ↔ WD1 RESET

If neither WD1\_TOVR is set in the first 500 ms nor WDOG service occurs, WD1\_LOCKOUT bit is set and an error counter, WD1\_ERR\_CNT, is incremented. WD1\_ERR\_CNT value is readable via SPI, see *Table 6*.

WATCHDOG block moves in reset, WD1 RESET.

When WD1\_LOCKOUT is set, all arming signals are disabled and deployment is inhibited.

#### 4.1.3 WD1 INITIAL - WD1 OVERRIDE

Figure 24. WD1 INITIAL ↔ WD1 OVERRIDE



The watchdog transition from WD1\_INITIAL state to WD1\_OVERRIDE state corresponds to the transition from INIT to DIAGNOSTIC mode of the IC, see *Figure 20*.

In order to enter this state, the pin WDT/TM must be biased to the voltage VWD\_OVERRIDE (refer to the spec for the value) and a proper SPI frame must be sent, accessing to the register \$35 WD\_TEST

Table 9. WD\_TEST

|                 | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2  | 1 | 0 |                                 |
|-----------------|-----|-----|----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|---|-----|-----|----|---|---|---------------------------------|
| \$35<br>WD_TEST | -   | w   | 1  |    | -  | -  |    |    | W  | D1_ | TES | ST |   |   |   |   | W | D2_ | TES | ST |   |   | b[15:8] = \$3C<br>b[7:0] = \$C3 |

DocID030428 Rev 1

**577** 

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

<sup>2.</sup> R = READ W = WRITE.

#### 4.1.4 WD1 INITIAL - WD1 RUN

When the watchdog routine is correctly serviced, the watchdog block enters in RUN MODE (*Figure 25*).

1ms / **WD1 INITIAL** WD1\_WDR= 500ms AND WD1\_TOVR=0/ WD1\_LOCKOUT=1 WD1\_ERR\_CNT++ WD1\_refresh OK/ WD1 WDR=0 WD1\_ERR\_TH\_WE=0 .. (WD1\_ERR\_CNT<WD1\_RETRY\_TH) WD1\_LOCKOUT=0 WD1\_ERROR/ **WD1 RESET** WD1\_LOCKOUT=1 WD1 ERR CNT+ WD1 RUN GAPGPS03128

Figure 25. WD1 INITIAL ↔ WD1 RUN ↔ WD1 RESET

The counter WD1\_ERR\_CNT holds its value during the transition WD1\_INITIAL WD1\_RUN.

If WD1\_ERR\_CNT has reached its threshold (that is WD1\_RETRY\_TH defined in \$28 WD\_RETRY\_CONF 28 see *Table 8*), WD1\_LOCKOUT bit remains set; otherwise lockout is automatically removed.

The number of allowed error cycles before permanently asserting the lockout is defined via SPI into the WD1\_RETRY\_TH.

The watchdog transition from WD1\_INITIAL state to WD1\_RUN state corresponds to the transition from INIT to DIAGNOSTIC mode of the IC, see *Figure 20*.

Watchdog service is defined into register WD1T:

(1) (2) 19 18 17 16 15 14 12 11 10 9 8 7 6 5 3 2 1 0 13 4 b[1:0] 00, 11 NOP \$2B W WD1T 01 = A10 = B b[1:0] 0 00, 11 NOP / 01 = A / 10 = B \$2B WD1 TIMER b[16:8] WD1 R WD1 TIMER WD1T timer value, step 8 µs or 64 µs in WD\_RUN or WD1 TEST

**Table 10. \$2B WD1T** 

- 1. I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.



WD1\_TIMER counter controls the correct watchdog service. Its parameters are programmed in \$2A WDTCR register in INIT IC state.

The counter WD1\_TIMER, is reset every time the watchdog is service (WD1CTL is valid).

If the watchdog is serviced too early or too late with respect to the time window, the watchdog error counter, WD1\_ERR\_CNT, is incremented. WD1\_LOCKOUT is set, watchdog status passes in WD1 RESET state for the management; the watchdog error WD1\_WDR is set and readable via SPI in \$00 FLTST register, see *Table 7*.

RESET pin is asserted with a time defined in the data sheet (TWD1\_RST).

In Figure 26 is sketched the WD1 service.



Figure 26. WATCHDOG service

If more than one WD1 with the same key value is received (for example A instead of B, see *Figure 26*), the WD1 counter is not refreshed until the correct key value is received in the defined time window (WDTMIN, WDTDELTA) and no error signals are asserted.

If more than one WD1 with the same key value (....A A A instead of ...A and then B) is received no error signals are asserted even if the WD1 refresh command arrives before the counter has reached WDTMIN programmed value.

47/

## 4.1.5 WD1 RUN - WD1 test

WD1\_TEST state can be reached only from WD1\_RUN state through the same SPI command used to move in WD1 OVERRIDE:

Table 11. \$35 WD\_TEST

|                 | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3   | 2  | 1 | 0 |                                 |
|-----------------|-----|-----|----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|---|------|-----|----|---|---|---------------------------------|
| \$35<br>WD_TEST | -   | w   | -  | -  | -  | 1  |    |    | W  | D1_ | TES | ST |   |   |   |   | W | 'D2_ | TES | ST |   |   | b[15:8] = \$3C<br>b[7:0] = \$C3 |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

This state generates a WD1\_ERROR, without asserting WD1\_LOCKOUT=1.

This is used to test the WD refresh. Typically it is implemented once per power up, even if there are no restrictions to access this mode in other moments.

In this state, deployments are not enabled.

Servicing WD1, watchdog turns back into WD1 RUN.



<sup>2.</sup> R = READ W = WRITE.

## 4.1.6 Algorithmic watchdog WD2

WD2 is an algorithmic watchdog managed starting from two default parameters, WD2\_PREV\_KEY and WD2\_SEED, on a base time TMR2 and the number of error is counted in two counters, WD2\_RETRY and WD2\_ERR.

The overview of WD2 functionality, with signals and counters involved in WD2 management is summarized in *Figure 27*:



Figure 27. WD2 functionality



42/106 DocID030428 Rev 1

## 4.1.7 Algorithmic watchdog WD2 - WD2 INIT

Watchdog status is readable via SPI:

Table 12. \$2C WD\_STATE

|               | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13          | 12 | 11 | 10 | 9         | 8 | 7 | 6          | 5 | 4 | 3 | 2         | 1 | 0 |         |                                                                                                                                                           |
|---------------|-----|-----|----|----|----|----|----|----|-------------|----|----|----|-----------|---|---|------------|---|---|---|-----------|---|---|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|               |     |     |    |    |    |    |    |    | L           |    |    |    |           |   |   | L          | _ |   |   |           |   |   | b[10:8] | 000 = INITIAL<br>001 = RUN<br>010 = TEST<br>011 = RESET<br>100 = OVERRIDE                                                                                 |
| \$2C WD_STATE | -   | R   |    |    |    |    |    |    | WD1 EBB CNT |    |    |    | WD1_STATE |   |   | MD EBB CNT |   |   |   | HATS SOLM |   |   | b[3:0]  | 0000 = INITIAL<br>0001 = OVERRIDE<br>0010 = INITSEED<br>0011 = RUN<br>0100 = TEST<br>0101= QUAL<br>0110=LOCK<br>0111= STOPPING<br>1000=STOP<br>1001=RESET |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

Watchdog faults are readable via SPI in \$00 FLTSR register:

Table 13. \$00 FAULT STATE

|            | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14                 | 13       | 12 | 11 | 10     | 9      | 8       | 7      | 6      | 5       | 4 | 3 | 2 | 1 | 0 |  |
|------------|-----|-----|----|----|----|----|----|--------------------|----------|----|----|--------|--------|---------|--------|--------|---------|---|---|---|---|---|--|
| \$00 FLTSR | -   | R   |    |    |    |    |    | WD rathy ont [3:0] | ) of [0] |    |    | WD2_LO | WD2_TM | WD2_WDR | WD1_LO | WD1_TM | WD1_WDR |   |   |   |   |   |  |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

WD2INIT is the default state (from start up or SSM reset, if WD2 is not in WD2 STOP state) that means a specific default value for two parameters, WD2\_PREV\_KEY[7:0] and WD2\_SEED[7:0]. These parameters are available on SPI:

<sup>2.</sup> R = READ W = WRITE.

<sup>2.</sup> R = READ W = WRITE.

|                  |     |     |    |    |    |    |    |    | ٠.٠. | •   | •••  | •   |   |   |   | - |    |     |    |    |   |   |                                              |
|------------------|-----|-----|----|----|----|----|----|----|------|-----|------|-----|---|---|---|---|----|-----|----|----|---|---|----------------------------------------------|
|                  | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13   | 12  | 11   | 10  | 9 | 8 | 7 | 6 | 5  | 4   | 3  | 2  | 1 | 0 |                                              |
| \$33<br>WD2 SEED | -   | R   |    |    |    |    |    | ٧  | VD2  | _PR | REV. | _KE | Y |   |   |   | WI | D2_ | SE | ED |   |   | WD2_PREV_KEY<br>[15:8]<br>\$0D default value |
| WB2_022B         |     |     |    |    |    |    |    |    |      |     |      |     |   |   |   |   |    |     |    |    |   |   | WD2_SEED [7:0]<br>\$F0 default value         |

Table 14 \$33 WD2 SFFD

44/106

Based on WD2 PREV KEY and WD2 SEED default values readable in \$33 WD2 SEED register, the IC calculates the new key value as bitwise exclusive OR between the randomly generated seed and the key valid at the previous watchdog service step:

This value is the expected value of WD2 KEY from the microcontroller written in \$34 WD2 KEY register, indeed at the first step the microcontroller is supposed to read WD2 PREV KEY and WD2 SEED default values and elaborates WD2 KEY.

In case the elaboration of the key in the microcontroller provides the same code as the internal calculation, WD2 block passes from WD2INIT to INITSEED.

#### 4.1.8 Algorithmic watchdog WD2 - INITSEED

Once in INITSEED, TMR2 timer starts running. If TMR2 reaches its maximum value without any correct WD2 KEY, WD2 moves back to WD2INIT, otherwise a correct WD2 KEY determines the transition into WD2RUN.

#### 4.1.9 Algorithmic watchdog WD2 - WD2RUN

In WD2RUN, if WD2KEY is continuously recalculated and serviced by the microcontroller, WD2 remains in RUN; provided that also the WD1 is overridden or correctly serviced, the IC consequently moves from INIT to DIAG state, see Figure 20.

#### 4.1.10 Algorithmic watchdog WD2 - WD2QUAL

From WD2RUN, if WD2 is not serviced in TMR2 MAX, WD2 moves in WD2QUAL and counter WD2\_RETRY is incremented.

If threshold of WD2 RETRY counter is not reached, as WD2 is correctly serviced (correct WD2 KEY), WD2 turns back to WD2RUN, recording the event of "WD2 not serviced inside TMR2 MAX time" in the counter WD2 RETRY.

If in WD2QUAL WD2 is NOT correctly serviced (correct WD2\_KEY) in TMR2 MAX time, the counter WD2\_RETRY is incremented.

In WD2QUAL the procedure of waiting for a correct WD2\_KEY / increment of counter WD2\_RETRY proceeds until the counter WD2\_RETRY reaches its threshold, WD2 RETRY TH. In correspondence of threshold reached event, WD2 moves into

DocID030428 Rev 1



<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

<sup>2.</sup> R = READ W = WRITE.

WD2LOCK, WD2\_LOCKOUT signal is asserted and another counter, WD2\_ERRcnt, is incremented

WD2\_ERRcnt holds the number of time that the first counter WD2\_RETRY has reached its threshold, which is considered as WD2 not serviced correctly.

## 4.1.11 Algorithmic watchdog WD2 - WD2LOCK

In WD2LOCK, WD2\_LOCKOUT signal is asserted, which means that any arming and deployment events are inhibited.

Once in WD2LOCK and the threshold of the second counter WD2\_ERRcnt is not reached (WD2\_ERR\_TH),

- if WD2 is correctly serviced, WD2 remains in WD2LOCK.
- 2. if WD2 is NOT correctly serviced, WD2 moves into WD2RESET
- 3. if the microcontroller sends a specific SPI word, WD2\_RECOVER, WD2 moves back to WD2RUN, WD2\_RETRY counter restarts and WD2LOCKOUT signal is reset.

#### Table 15. \$32 WD2\_RECOVER

|                     | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3 | 2 | 1 | 0 |  |
|---------------------|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|------|---|---|---|---|--|
| \$32<br>WD2_RECOVER | -   | W   |    |    |    |    |    |    |    | -  | -  |    |   |   |   |   |   | \$AA | A |   |   |   |  |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

## 4.1.12 Algorithmic watchdog WD2 - WD2STOPPING - WD2STOP

Once in WD2LOCK and WD2\_ERR counter has reached its threshold, WD2\_ERR\_TH, WD2 moves into WD2STOPPING and, with 1ms low pulse on RESET pin, into WD2STOP.

The only way to change WD2 state is a POWER ON RESET.

## 4.1.13 Algorithmic watchdog WD2 - WD2RESET - WD2INIT

Once in WD2LOCK and the threshold of the second counter WD2\_ERR is not reached (WD2\_ERR\_TH) if WD2 is NOT correctly serviced, WD2 moves into WD2RESET.

From WD2RESET, WD2 turns into WD2INIT with 1ms low pulse on RESET pin, setting WD2 WDR and resetting WD2 TM.

<sup>2.</sup> R = READ W = WRITE.

## 4.1.14 Algorithmic watchdog WD2 - WD2OVERRIDE

From the first WD2 state, WD2INIT, WD2 can move in WD2OVERRIDE state through the same SPI command used to move WD1 in WD1OVERRIDE state:

Table 16. \$35 WD TEST

|                 | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12   | 11   | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2  | 1 | 0 |                                 |
|-----------------|-----|-----|----|----|----|----|----|----|----|------|------|----|---|---|---|---|---|-----|-----|----|---|---|---------------------------------|
| \$35<br>WD_TEST | -   | w   | -  | -  | -  | -  |    |    | W  | 'D1_ | _TES | ST |   |   |   |   | W | D2_ | TES | ST |   |   | b[15:8] = \$3C<br>b[7:0] = \$C3 |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

In correspondence WD2 LOCKOUT signal is reset.

Note that in order to override WD2 it is not required to have any high voltage on pin WDT/TM, as required for WD1.

## 4.1.15 Algorithmic watchdog WD2 - WD2TEST

From the WD2RUN state, WD2 can move in WD2TEST state through the same SPI command used to move WDx in WDxOVERRIDE state:

In correspondence WD2\_TM signal is set, and it is generated a 1ms low pulse on RESET signal without setting WD2\_LOCKOUT signal.

In WD2TEST as the WD2 is serviced, WD2 turns in WD2RUN state;

If in WD2TEST WD2 is NOT serviced in TMR2 time, WD2 moves into WD2RESET.

## 4.2 ER CAP features

The energy reserve capacitor connected to VER pin can be charged in an efficient way by means of a current generator.

Its capability is IER\_CHARGE. The current generator is activated or deactivated by SPI command only while in ACTIVE mode. Out of ACTIVE mode, the current generator is switched off in order to decouple ERBOOST node voltage from VER pin.

In order to discharge the energy reserve capacitor, there is an internal current generator controlled via SPI, IER DISCHARGE, high or low, when the IC is not in SLEEP mode.

Charge and discharge circuits are mutually exclusive.

Diagnostic available on energy reserve capacitor regards the ESR capacitor measurement and the capacitor value measurement.

46/106 DocID030428 Rev 1

<sup>2.</sup> R = READ W = WRITE.

## 4.2.1 ESR measurement

Here below is shown the procedure to be used in order to measure value of ESR related to  $C\_ER$ .

Refer to *Figure 28* for the measurement phases:

VER SW SI

Figure 28. ESR measurement phases

Set up: the test can be performed in DIAGNOSTIC state, readable on register \$04:

(1) (2) 19 13 12 11 10 9 8 2 18 17 16 15 14 7 6 5 3 1 0 4 STATE CTL\_STATE b[10:9] 001: DIAG CTL \$04 0 0 0 0 0 R 0 0 0 0 0 0 0 0 0 SYS\_STATE POWER\_ b[2:0] 010: RUN

Table 17. \$04 SYS\_STATE

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.



2. R = READ; W = WRITE.

C\_ER has to be previously charged at VER, through ER\_CHARGE ON:

Table 18. \$02 SYS\_CTL (1)

|                 | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8           | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |     |                 |
|-----------------|-----|-----|----|----|----|----|----|----|----|----|----|----|-------|-------------|-----|---|---|---|---|---|---|---|-----|-----------------|
| \$02<br>SYS_CTL |     | w   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | BST_V | NH CH       | ī 1 |   |   |   |   |   |   |   | 9:  | 0=23V<br>1=33V  |
| SYS_CTL         | -   | VV  |    | U  | U  | J  | J  | U  | U  | J  | U  |    | ER_B  | 2<br>2<br>2 |     |   |   |   |   |   |   |   | 8-7 | 01=ER_CHARGE ON |

- I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES
   (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.

Once C\_ER has been charged, ER\_CHARGE has to be switched OFF:

Table 19. \$02 SYS\_CTL (2)

|                 | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8 | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |     |                  |
|-----------------|-----|-----|----|----|----|----|----|----|----|----|----|----|-------|---|--------|---|---|---|---|---|---|---|-----|------------------|
| \$02<br>SYS_CTL |     | w   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | BST_V |   | -<br>  |   |   |   |   |   |   |   | 9   | 0=23V<br>1=33V   |
| SYS_CTL         | _   | * * |    |    |    |    |    | 0  | J  | J  | J  |    | ER_B  | 0 | ر<br>آ |   |   |   |   |   |   |   | 8-7 | 00=ER_CHARGE OFF |

- 1. I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.

## **Test procedure**

Test can be performed only in HIGH LEVEL DIAGNOSTIC mode, setting \$38 LPDIAGREQ:

Table 20. \$38 LPDIAGREQ

|                   | (1) | (2) | 19 | 18 | 17 | 16               | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6               | 5 | 4 | 3 | 2 | 1 | 0 |        |                                  |
|-------------------|-----|-----|----|----|----|------------------|----|----|----|----|----|----|---|---|---|-----------------|---|---|---|---|---|---|--------|----------------------------------|
|                   |     |     |    |    |    |                  |    |    |    |    |    |    |   |   |   | SELECTOR        |   |   |   |   |   |   | 16     | 1= high level                    |
|                   |     |     |    |    |    | level            |    |    |    |    |    |    |   |   |   | - 1             |   |   |   |   |   |   | b[7:5] | 100= ER cap<br>ESR meas          |
| \$38<br>LPDIAGREQ | (1) | W   | 0  | 0  | 0  | Wo I/ High /I ow | 0  | 0  | 0  | 0  | 0  | ×  | X | X |   | HIGH_LEVEL_DIAG |   | X | 1 | 1 | 1 | 1 | b[3:0] | 1100÷1111 no<br>Chanel selection |

1. I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

48/106 DocID030428 Rev 1

- R = READ W = WRITE.
  - SW signal drives the MOS M2 ON and then M1 is driven ON too. Current I flows as indicated in the figure. Current generator IER\_DISCHARGE\_HIGH is OFF (through SI signal).
  - SW signal drives the correspondent MOS in OFF state; the capacitor between Gate and Source of M1 behaves as a memory and holds the voltage stored then M1 remains ON. Current generator IER\_DISCHARGE\_HIGH is still OFF, thorough SI signal. V2 voltage measurement of V\_SENSE signal is taken (V2~1.9V+Voffset)
  - 3. Current generator IER\_DISCHARGE\_HIGH is driven ON through SI signal for the whole time of the measurement. IER\_DISCHARGE\_HIGH current is sunk from C\_ER determining a voltage drop across R\_ESR. This voltage drop is the step down of VER signal that is reported on V\_SENSE signal.
  - 4. Current generator IER\_DISCHARGE\_HIGH ON discharges C\_ER with a fixed current. At the end of the measurement, V1 voltage measurement of V\_SENSE that takes care of the C\_ER discharge is taken.
  - 5. Current generator IER\_DISCHARGE\_HIGH is switched OFF and the last V\_SENSE measurement (V3) is then taken.

The three voltage values, V1, V2 and V3, are automatically stored in this way:

DIAGCTRLA ADCREQ \$15 ADCRES=V2
DIAGCTRLB ADCREQ \$14 ADCRES=V1
DIAGCTRLC ADCREQ \$16 ADCRES=V3

The three values (V1, V2 and V3) are converted from binary to decimal and then in voltage value considering that each bit corresponds to 2.5/1024 = 2.4 mV.

R ESR is so calculated:

$$V_2 = V_1 + R \cdot I + (V_2 - V_3)$$

$$\to R = \frac{V_3 - V_1}{I}$$

GAPGPS03131

where  $I = I_{ER\ DISCHARGE\ HIGH}$ , reported in the spec.

Considering the gain of the second op amp before the ADC (see *Figure 28*,) and considering the residual offset introduced by the measurement circuit, the formula to be finally used becomes:

$$ESR_{ERCAP} = \frac{V_3 - V_1}{G_{ER\_ESR} \cdot I_{ER\_DISCHARGE\_HIGH}} + OFF_{ER\_ESR}$$
<sub>GAPGPS03132</sub>

#### **Example**

Figure 29 shows an example of a measurement performed.

The relevant signals are IER DISCHARGE HIGH (green) and VER (pink)



Figure 29. ESR measurement

Table 21. ESR measurement

|             | (ADCREQ)16 | (ADCRES)10 | 2.5/1024=2.4mV        |                                      |
|-------------|------------|------------|-----------------------|--------------------------------------|
| DAIGCTRL_3A | \$15 (V2)  | 809        | 809 * 2.4 mV = 1.98 V |                                      |
| DAIGCTRL_3B | \$14 (V1)  | 411        | 411 * 2.4 mV = 1.00 V | $R = (2.02-1)V/(3*0.65A)=523m\Omega$ |
| DAIGCTRL_3C | \$16 (V3)  | 829        | 829 * 2.4 mV = 2.02 V |                                      |

Supposing I= IER\_DISCHARGE\_HIGH = 640 mA (typ by spec)

## 4.3 ER CAP measurement

The ER CAP measurement is performed through three VER measurements via ADC.

ER\_CAP measurement requires first ER\_CAP charged, then discharged through a fixed current for a fixed chosen time (T1) and then re-charged for the same discharge time (T2 being T2=T1=T):

- 1. Definition of discharge (T1) and charge time (T2) with T1=T2=T
- 2. C\_ER has been previously charged through I1 at roughly at half of ER\_BOOST
- 3. switch off the ER CHARGE via SPI
- 4. read the first VER value, named Vstart
- 5. switch on ER DISCHARGE to discharge the capacitor through I2 in T1 time
- 6. switch off ER\_DISCHARGE LOW
- 7. read the second VER value, named Vstop
- 8. switch on ER\_CHARGE and re-charge the capacitor through I1 in T2 time
- 9. switch off ER CHARGE
- 10. read the third VER value, named Vend

A sketch of the procedure is described in Figure 30.

50/106 DocID030428 Rev 1





Figure 30. ER CAP measurement

In order to avoid ESR error contribution, each VER measurement is performed when no current flows through ER cap (except the C\_ER leakage ILEAK).

 $T_1$  = predefined discharge time

 $T_2$  = predefined charge time, same as charge time

$$T_1 = T_2 = T$$

 $I_1$  = charge current

I<sub>2</sub> = discharge current, same as charge current

$$I_1 = I_2 = I$$

I<sub>LEAK</sub> = leakage current

During C\_ER discharge

$$Vstop - Vstart = -\frac{(I_2 + I_{LEAK}) * T}{C}$$
 a)

GAPGPS03135

During C\_ER charge

Vend - Vstopt = 
$$\frac{(I_1 - I_{LEAK}) * T}{C}$$
 b)

GAPGPS03136

Once measured Vstart, Vstop and Vend, assuming the current which charges the capacitor as positive, equation (C) can be obtained by linear combination of equations (a) and (b)

(b) – (a):  

$$Vend - Vstop - (Vstop - Vstart) = \frac{I_1 + I_{LEAK}}{C} T_1 + \frac{I_2 - I_{LEAK}}{C} T_2$$

$$C = \frac{2 \cdot I \cdot T}{Vstart + Vend - 2 \cdot Vstop}$$
GAPGPS03137

I: refers to the datasheet for the value.

#### **Example**

T= 20 ms VER~15 V





$$C = \frac{2 \cdot I \cdot T}{\text{Vstart + Vend - 2 \cdot Vstop}} = \frac{2 \cdot 65 \cdot 10^{-3} \cdot 20 \cdot 10^{-3}}{(434 + 435 - 2 \cdot 427) \cdot 15 \cdot \frac{2.5}{1024}} = 4.7 \text{mF}$$

The reason why the measurement procedure has been implemented starting from ~15 V is to have the possibility to show a constant IER\_DISCHARGE\_LOW/ IER\_CHARGE.

The user can decide the charge and discharge time based on the ER CAP used in application, in order to maximize the differential voltage and then improve the accuracy.

Anyway, a timeout on ER Discharge current has been implemented to prevent thermal issue, so the discharge time cannot be longer than 350 ms.

**577** 

52/106 DocID030428 Rev 1

# 5 Arming

The device offers the possibility to select either an internal or external safing engine.

In case of internal safing engine, data from the satellites are elaborated based on a configurable algorithm in order to assert the internal arming signals; in case of external safing engine, the microcontroller is responsible for the arming algorithm.

# 5.1 Internal safing engine

SAFESEL bit[3], \$01 SYS\_CFG:

0 = internal safe engine

In case of internal safing engine, the assignment of loops matrix (LOOPx) to ARM signal is defined by LOOP\_MATRIX\_ARMx registers:

\$6E LOOP\_MATRIX\_ARM1 \$6F LOOP\_MATRIX\_ARM2 \$70 LOOP\_MATRIX\_ARM3 \$71 LOOP\_MATRIX\_ARM4

Table 22. \$6E LOOP\_MATRIX\_ARM1

|                              | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11             | 10     | 9      | 8      | 7      | 6  | 5      | 4      | 3      | 2  | 1   | 0  |     |                                         |
|------------------------------|-----|-----|----|----|----|----|----|----|----|----|----------------|--------|--------|--------|--------|----|--------|--------|--------|----|-----|----|-----|-----------------------------------------|
| 205                          |     |     |    |    |    |    |    |    |    |    | -B             | A      | 6-     | .8     | .7     | -6 | -5     | -4     | .3     | -2 | L1  | L0 | 0   | ARMx signal not associated with LOOPy   |
| \$6E<br>LOOP_MATRI<br>X_ARM1 | D   | w   | 0  | 0  | 0  | 0  | х  | Х  | X  | Х  | — <sub> </sub> | ARM1_L | ARM1_L | ARM1_L | ARM1_L |    | ARM1_L | ARM1_L | ARM1_L | =  | _ i |    | 1   | ARMx signal<br>associated with<br>LOOPy |
|                              |     |     |    |    |    |    |    |    |    |    |                |        |        |        |        |    |        |        |        |    |     |    | Res | et SSM_RESET                            |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

Once the sensor data has been captured, it is elaborated by the internal safing algorithm.

Each safing record (or their elaboration based on combine function - COMB = 1) is compared with the correspondent threshold.

Thresholds are always

- user defined
- programmed in absolute value (unsigned, no matter if applied to a single or a combination of safing record data)
- 16 bit length maximum

The safing records data or their combination is compared with the SAF\_TH.

<sup>2.</sup> R = READ W = WRITE.

\$DF SAF\_THRESHOLD\_1 \$EE SAF\_THRESHOLD\_16

#### Table 23. \$DF SAF\_THRESHOLD\_1

|                         | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8   | 7   | 6   | 5   | 4 | 3 | 2 | 1 | 0 |                         |
|-------------------------|-----|-----|----|----|----|----|----|----|----|----|----|-----|----|-----|-----|-----|-----|---|---|---|---|---|-------------------------|
| \$DF<br>SAF_THRESHOLD_1 | D   | w   | x  | x  | х  | x  |    |    |    |    | SA | F_T | HR | RES | SHC | DLE | )_1 |   |   |   |   |   | cleared by<br>SSM_RESET |

- I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES
   (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.

Inside the IC there are two dedicated counters (POS\_COUNT, NEG\_COUNT) with features defined in \$66 SAF\_ALGO\_CONF:

Table 24. \$66 SAF\_ALGO\_CONF

|                       | (1) | (2) | 19 | 18 | 17 | 16 | 15      | 14 | 13 | 12  | 11  | 10 | 9  | 8   | 7   | 6  | 5  | 4   | 3   | 2   | 1   | 0   |                         |
|-----------------------|-----|-----|----|----|----|----|---------|----|----|-----|-----|----|----|-----|-----|----|----|-----|-----|-----|-----|-----|-------------------------|
| \$66<br>SAF_ALGO_CONF | D   | w   | 0  | 0  | 0  | 0  | NO DATA | X  | AF | 1MS | Ν_Τ | Н  | AF | RMF | P_] | ГН | SU | B_V | ⁄AL | ADI | D_V | /AL | cleared by<br>SSM_RESET |

- I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES
   (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.

If safing record data > +|SAF\_TH| → positive counter, POS\_COUNT, is incremented of ADD VAL the counter is decremented of SUB VAL otherwise;

If safing record data < - $|SAF_TH| \rightarrow$  negative counter, NEG\_COUNT is incremented of ADD VAL; the counter is decremented of SUB VAL otherwise.

The value of the two counters, POS\_COUNT and NEG\_COUNT, are respectively compared with the threshold ARMP\_TH and ARMN\_TH to define ARMN and ARMP signals.

If POS\_COUNT ≥ ARMP\_TH → ARMP set

If NEG COUNT ≥ ARMN TH → ARMN set

Based on ARMSEL bit (register \$EF-\$FE, see Section 5.3) and on ARMP/ARMN result, the internal arming flags will be asserted or not.

In case the sample cycle time is elapsed (microcontroller has read the register bit \$FF SAF\_CC, typically every 500us but there is no implemented restrictions inside the IC about the value of this time), there are two possibilities.

- 1. sensor data have been received (CC\_x=1), so the arming processing has been run successfully
- no data has been received (CC\_x=0)

In this last case (no data received) it is possible to configure how the IC behaves:

NO DATA = 1 no data received event is considered in a similar way of data below threshold (arming counters decremented);

**577** 

NO DATA = 0 no data received events reset the arming counters (more severe alternative)

During a sampling cycle time, each safing record is able to elaborate only one data coming from the related sensor;

once a data has been elaborated by the safing record logic, the correspondent flag is set in the register \$FF SAF\_CC (CC\_i bit=1). Should a new data come without the SAF\_CC having been read from the microcontroller (that means CC\_i still set), the data is ignored.

• CC (Compare Complete) - feedback from safing state machine indicating data received and processed.

This internal flag is cleared by the microcontroller on each sensor sampling period.

- CCi bit[i-1], i = 1÷16:
- 0 = compare not completed for record i
- 1 = compare completed for record i

Table 25. \$FF SAF\_CC

|             | (1) | (2) | 19 | 18 | 17 | 16 | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8    | 7    | 6    | 5                 | 4    | 3    | 2    | 1    | 0    |                                           |
|-------------|-----|-----|----|----|----|----|-------|-------|-------|-------|-------|-------|-------|------|------|------|-------------------|------|------|------|------|------|-------------------------------------------|
| \$FF SAF_CC | -   | R   | 0  | 0  | 0  | 0  | CC_16 | CC_15 | CC_14 | CC_13 | CC_12 | CC_11 | CC_10 | 6 33 | 8_00 | CC_7 | 9 <sup>-</sup> 00 | CC_5 | CC_4 | cc_3 | CC_2 | CC_1 | cleared by<br>SSM_RESET or<br>SPI readout |

- I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES
   (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.

SAF\_CC register (\$FF), together with ARM\_state (\$6A) ARMINT\_x, b[5:2], see *Table 26* can be read both through Global and RS SPIs.

Table 26. \$6A ARM STATE

|                   | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9         | 8              | 7             | 6         | 5        | 4        | 3        | 2        | 1 | 0 |                                           |
|-------------------|-----|-----|----|----|----|----|----|----|----|----|----|----|-----------|----------------|---------------|-----------|----------|----------|----------|----------|---|---|-------------------------------------------|
| \$6A<br>ARM_STATE | -   | R   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | PSIINHINT | PSINH_EXP_TIME | ACL_PIN_STATE | ACL_VALID | ARMINT_4 | ARMINT_3 | ARMINT_2 | ARMINT_1 | 0 | 0 | cleared by<br>SSM_RESET or<br>SPI readout |

- 1. I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.

# 5.2 External safing engine

SAFESEL bit[3], \$01 SYS\_CFG:

1 = external safe engine

In case of external safing engine, the assignment of loops matrix (LOOPx) to ARM signal is defined as below described:

ARM1, ARM2, ARM3 are associated to the High Sides (FENH, active high) based on the configuration of the registers:

\$6E LOOP\_MATRIX\_ARM1

\$6F LOOP\_MATRIX\_ARM2

\$70 LOOP\_MATRIX\_ARM3

(2) 19 18 17 16 15 14 13 12 11 9 8 7 2 10 6 5 4 3 1 0 ARMx signal not associated with LOOPy 9 8  $\Gamma$  $\Box$  $\Box$ \$6E ARMx signal ARM1 ARM1 **ARM1 ARM1** ARM1 **ARM1** ARM1 **ARM1** ARM1 LOOP MATRID W 0 0 0 0 Χ Χ Χ Х **ARM1** associated with X ARM1 LOOPy Reset SSM RESET

Table 27. \$6E LOOP\_MATRIX\_ARM1

ARM4 is associated to all the Low Side enable (FENL, active low)

In this case the meaning of the register \$71 LOOP\_MATRIX\_ARM4 is no more relevant being all the Low Side assigned to ARM4; in case of external safing engine the user should take care to distribute all the 12 loops available over the registers \$6E-70.

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / -= ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

<sup>2.</sup> R = READ W = WRITE.

## 5.3 Safing records

The IC is able to manage data from sensors either on board or remotely located, connected to the system via SPI (SPI\_RS, SAF\_CSx) or via RSUx interface.

In case of sensors' SPI connection, there is a regular communication between the main microcontroller and the sensors through multiple SPI messages. Since not all communications between sensors and the microcontroller contain data, it is important for the decoder to properly sort the communications and extract only the targeted data.

The solution involves defining specific masking functions, programmed by the user; the IC is able to manage either 16 or 32 bit length masks.

Sensors data are processed in order to engage the ARMING internal procedure through the safing engine.

The IC is equipped with the possibility to manage two kinds of mask.

- 16 bit length masks: Applied to SAFING\_RECORD\_1÷SAFING\_RECORD\_13, defined with the correspondent SAF\_REQ\_MASK, SAF\_REQ\_TARGET, SAF\_RESP\_MASK, SAF\_RESP\_TARGET.
- 2. 32 bit length masks:
  Applied to SAFING\_RECORD\_14÷SAFING\_RECORD\_16, defined with the correspondent SAF\_REQ\_MASK, SAF\_REQ\_TARGET, SAF\_RESP\_MASK, SAF\_RESP\_TARGET. Each mask is composed by 2x16bit words, defined in the registers SAFXXX\_pt1 and SAFXXX\_pt2.

Despite the length of the masks, all the safing records are designed to manage 16 bit length max sensor data.

Inside the safing record, the sensor data can be located in a different position.

If the safing record is 16 bit length, data fill the safing record itself according to the procedure described in 6.4 SPI SENSOR DATA DECODING (16 bit SAFING RECORD MASK);

If the safing record is 32 bit length, data are still 16bit length, but data can be distributed over the first MSB 16 bit, the last LSB 16 bit or across them:

| 31 | 30 | 29 | 28  | 27   | 26   | 25   | 24  | 23   | 22   | 21   | 20   | 19   | 18    | 17   | 16 | 15  | 14   | 13  | 12    | 11    | 10    | 9    | 8    | 7      | 6     | 5    | 4  | 3 | 2 | 1 | 0 |
|----|----|----|-----|------|------|------|-----|------|------|------|------|------|-------|------|----|-----|------|-----|-------|-------|-------|------|------|--------|-------|------|----|---|---|---|---|
|    |    |    | Acc | eler | atio | n da | ata | with | in t | he 1 | 16 N | 1SB  |       |      |    | 1   | 1    | 1   | 1     | 1     | 1     | /    | 1    | 1      | 1     | /    | /  | / | / | / | / |
| 1  | /  | 1  | /   | /    | 1    | 1    | 1   | 1    | 1    | 1    | 1    | /    | 1     | /    | 1  |     |      |     | Acc   | elera | atior | n da | ta w | vithii | n the | = 16 | LS | В |   |   |   |
| 1  | /  | 1  | /   | 1    | 1    | 1    | 1   | 1    | 1    | 1    | A    | \cce | elera | atio | า  | dat | a ac | ros | s the | e 1s  | t an  | d 2r | nd 1 | 6 bi   | t wo  | rds  | /  | / | / | / | / |

Each safing record has SPI accessible registers defined in the SPI command tables and summarized below:

- Request Mask and Request Target to understand which sensor the microcontroller is addressing
- Response Mask and Response Target to identify the sensor response
- Data Mask to extract relevant sensor data from the response
- Safing Threshold specific value that sets the comparator limit for successful arming

- Control, \$EF÷\$FE SAF\_CONTROL\_x
  - IF, In Frame to indicate serial data response is "in frame". There are two types of potential serial data response, "in-frame" and "out of frame".
     IF bit[0]:

0 = out of frame response

1 = in frame response

CS - to align safing record with a specific SPI CS. The device contains 5 SPI CS inputs for the safing function (CS\_RS, SAF\_CSx)

CSx bit [2:0]:

000, 110, 111 no selection for record x

001= SAF\_CS0

010= SAF CS1

011= SAF\_CS2

100= SAF\_CS3

101= CS RS

 ARM - there are four internal arming signals, each active record is assigned or mapped to any arming signal. Several safing records can be mapped to a single arming output. ARMx outputs can be enabled also simultaneously.
 ARM4x bit[7]:

0= safing record not assigned to ARM4INT

1= safing record assigned to ARM4INT

The same as the other 3 bits, ARM3x[6], ARM2x[5], ARM1x[4]

 Dwell - Once an arming condition is detected, the IC remains armed for the specified dwell time.

DWELLx bit[9:8]:

00 = 2048 ms

01 = 256 ms

10 = 32 ms

11 = 0 ms

Figure 32. DWELL time



For each safing record a specific Dwell value is programmed. In case multiple safing records with different Dwell values are assigned to a specific ARMx signal, the longer value is used

 Comb (Combined Data) - specific solution for dual axis high-g sensors specifically oriented off-axis (see 6.6).

COMBx bit[10]:

0 = combine function disabled

1 = combine function enabled

Lim En (Limit Enable) - to enable PSI5 out-of-range control.

LIM Enx bit[11]:

0 = data range limit disabled

1 = data range limit enabled

 Lim Sel (Limit Select) - to select PSI5 out-of-range thresholds between 8-bit and 10-bit protocol.

LIM SELx bit[12]:

0 = 8 bit data range limit, |data|>120d not recognized as valid data

1 = 10 bit data range limit, |data|>480d not recognized as valid data

SPIFLDSELx bit[13]: - only for 16bit masks safing records:

0 = sensor data are located in the first 16 bit of SPI MISO

1 = sensor data are located in the second 16 bit of SPI MISO

If the SPI message is shorter than 32 bit, SPIFLDSELx is don't care

 ARMSELx - to select positive or negative acceleration ARMSELx bit[15, 14]:

00, 11 = ARMP or ARMN

01 = ARMP

10 = ARMN

Table 28. \$EF÷FE SAF\_CONTROL\_x

|                                | (1) | (2) | 19 | 18 | 17 | 16 | 15        | 14   | 13       | 12       | 11      | 10    | 9 | 8               | 7     | 6     | 5     | 4     | 3 | 2        | 1 | 0 |                                                          |
|--------------------------------|-----|-----|----|----|----|----|-----------|------|----------|----------|---------|-------|---|-----------------|-------|-------|-------|-------|---|----------|---|---|----------------------------------------------------------|
| \$EF÷\$FE<br>SAF_CONT<br>ROL_x | D   | w   | 0  | 0  | 0  | 0  | A DMCEL & | MOEL | SPIFLDSE | LIM_SELx | LIM_ENx | COMBx | > | )<br> <br> <br> | ARM4x | ARM3x | ARM2x | ARM1x |   | CSx[2:0] |   | 포 | Updated by<br>SSM_RESET or<br>SPI write in DIAG<br>state |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

The En (Record Enable) bit for any record is programmable as ON or OFF at any time and will enable/disable the record itself upon the following SATSYNC.

 En (Record Enable) - determines when a safing record is active or disabled EN\_SAFi bit[i-1], 1=1÷16:

0 = disabled

1 = enabled

<sup>2.</sup> R = READ W = WRITE.

|                            |     |     |    |    |    |    |          |          |          | -        |        |        | _   | -       |         |         |         |         |         |         |   |       |                                         |
|----------------------------|-----|-----|----|----|----|----|----------|----------|----------|----------|--------|--------|-----|---------|---------|---------|---------|---------|---------|---------|---|-------|-----------------------------------------|
|                            | (1) | (2) | 19 | 18 | 17 | 16 | 15       | 14       | 13       | 12       | 11     | 10     | 9   | 8       | 7       | 6       | 5       | 4       | 3       | 2       | 1 | 0     |                                         |
| \$EF÷\$FE<br>SAF_CONTROL_x | (1) | w   | 0  | 0  | 0  | 0  | EN_SAF16 | EN_SAF15 | EN_SAF14 | EN_SAF13 | N_SAF1 | N_SAF1 | ا ح | EN_SAF9 | EN_SAF8 | EN_SAF7 | EN_SAF6 | EN_SAF5 | EN_SAF4 | EN_SAF3 | z | N_SAF | Updated by<br>SSM_RESET or SPI<br>write |

Table 29. \$7F SAF ENABLE

Safing record can only be evaluated on the first matching input packet. Any further data packet matches are ignored (i.e. once CC is set, record can't be processed until next SATSYNC)

If input packet matches multiple safing records, the safing engine will process all of them and treat them independently.

Safing Engine must not process sensor data in any state but in Safing state.

All safing records are cleared on SSM RESET.

Following the sketch below, see *Figure 33*, when one of SAF\_CS0 ÷ SAF\_CS3 is asserted, IC is able both to capture data on MOSI\_RS and sniff traffic from MISO\_RS line so the communication between microcontroller and sensor is monitored. In this case the IC does not apply any integrity check on SPI information sniffed (parity, CRC or whatever) but it simply verifies that a minimum of 16bit has been transmitted for each SPI frame.

The microcontroller has to guarantee that SAF\_CSx, and CS\_RS are not asserted simultaneously; should it happen, the SPI frame is ignored. The CS\_G is not involved in this check.



Figure 33. SPI signal and SAF\_CS0÷SAF\_CS3

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / -= ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

<sup>2.</sup> R = READ W = WRITE.

# 5.4 SPI sensor data decoding (16 bit Safing record mask)

Supposing, for example, the sensors are so organized:

b[14,13] = channel selection, x or y

b[9:0] = data sensor (10 bit data length)

b12 = parity bit

b[11,10] = type of data in sensor data field (acceleration, self-test, error)

| bit | 15 | 14  | 13  | 12 | 11  | 10  | 9 | 8 | 7 | 6    | 5    | 4    | 3    | 2 | 1 | 0 |
|-----|----|-----|-----|----|-----|-----|---|---|---|------|------|------|------|---|---|---|
| so  | 0  | CH1 | CH0 | Р  | ST1 | ST0 |   |   |   | ACCE | LERA | TION | DATA |   |   |   |

If the microcontroller request is (MOSI):

| bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| SI  | 0  | 0  | 1  | Χ  | 1  | 0  |   |   | > | < |   |   | 1 | 0 | 1 | 0 |

b[14:13] = 01 this codification can be for example the sensor for x acceleration

b12 = don't care

b[11,10] = 10 this codification can indicate for example that in the data field are

reported acceleration data

b[9:4] = don't care. These are the data the sensor sends. Microcontroller reads

them, but doesn't write them

b[3:0] = address of the sensor, for example 1010 that is sensor n.3

## 5.4.1 Request Mask (MOSI line)

Setting SAF\_REQ\_MASK[15:0] bit in SAF\_REQ\_MASK\_x, it is defined, inside the frame, the position of the bit to be considered in the data received. This is done setting bit in SAF\_REQ\_MASK\_x located in the position to consider.

Extraction of data is done putting in AND (bit per bit) the SAF\_REQ\_MASK with the data received.

SAF\_REQ\_MASK is applied on messages recorded from MOSI pin; useful information is considered to be transmitted always on first 16 bit block.

\$80 SAF\_REQ\_MASK\_1 ÷ \$8C SAF\_REQ\_MASK\_13

## Table 30. \$80 SAF\_REQ\_MASK\_1

|                        | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7    | 6   | 5   | 4 | 3 | 2 | 1 | 0 |                         |
|------------------------|-----|-----|----|----|----|----|----|----|----|----|----|----|-----|-----|------|-----|-----|---|---|---|---|---|-------------------------|
| \$80<br>SAF_REQ_MASK_1 | D   | w   | x  | x  | x  | x  |    |    |    |    |    | SA | F_F | REG | Q_M. | ASŁ | <_x |   |   |   |   |   | cleared by<br>SSM_RESET |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

<sup>2.</sup> R = READ W = WRITE.

In the example SAF\_REQ\_MASKx[15:0]:

| bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|     | 1  | 1  | 1  | 0  | 1  | 1  |   |   | ( | ) |   |   | 1 | 1 | 1 | 1 |

b[15:13], b[11:10], b[3:0] set

b12, b[9:4] correspond to the position of the bit not to be considered; they are left at 0.

## 5.4.2 Request Target (MOSI line)

Considering the bit selected through SAF\_REQ\_MASK, the value these bit have to assume is indicated REQUEST TARGET.

So:

in REQUEST MASK it is defined which bit position to look at;

The expected values of the bit, which are in the positions indicated by SAF\_REQ\_MASK, are defined in SAF\_REQ\_TARGET.

This procedure is the definition of the filter of all the data exchanged: which bit to consider and which value they should have.

\$93 SAF\_REQ\_TARGET\_1 ÷ \$9F SAF\_REQ\_TARGET\_13

Table 31. \$93 SAF\_REQ\_TARGET\_1

|                          | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7    | 6   | 5   | 4  | 3 | 2 | 1 | 0 |                         |
|--------------------------|-----|-----|----|----|----|----|----|----|----|----|----|----|-----|-----|------|-----|-----|----|---|---|---|---|-------------------------|
| \$93<br>SAF_REQ_TARGET_1 | D   | w   | x  | х  | x  | x  |    |    |    |    | S  | AF | _RE | EQ_ | _TAI | RGI | ET_ | _x |   |   |   |   | cleared by<br>SSM_RESET |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

In the example SAF\_REQ\_TARGETx[15:0]:

| bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|     | 0  | 0  | 1  | Х  | 1  | 0  |   |   | > | ( |   |   | 1 | 0 | 1 | 0 |

b15 is expected 0

b[14:13] is expected to be 01 being x axis data

b12 is the parity bit, so a priori is not defined

b[11:10] is expected to be 10 because it is supposed that the data received from sensor will be the acceleration

b[3:0] is expected to be 1010 being selected the sensor number 3

b[9:4] are the data, so their value is not known a priori.

SI[15:0] & SAF\_REQ\_MASKx[15:0] = SAF\_REQ\_TARGETx[15:0]

<sup>2.</sup> R = READ W = WRITE

## 5.4.3 Response Mask (MISO line)

To identify the sensor response, it is defined, inside the frame received from the sensor (MISO), the position of those bit to be considered.

This is done setting the bit, in SAF\_RESP\_MASK\_x, located in the position of the bit to be considered.

\$A6 SAF\_RESP\_MASK\_1 ÷ \$B2 SAF\_RESP\_MASK\_13

Table 32. \$A6 SAF\_RESP\_MASK\_1

|                         | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8   | 7   | 6   | 5   | 4 | 3 | 2 | 1 | 0 |                         |
|-------------------------|-----|-----|----|----|----|----|----|----|----|----|----|-----|----|-----|-----|-----|-----|---|---|---|---|---|-------------------------|
| \$A6<br>SAF_RESP_MASK_1 | D   | w   | х  | х  | х  | х  |    |    |    |    | Ş  | SAF | _R | ESF | ₽_N | 1AS | K_> | < |   |   |   |   | cleared by<br>SSM_RESET |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

In the example SAF\_RESP\_MASKx[15:0]:

The SAF\_RESP\_MASK allows choosing one message with respect to all that runs on SPI bus.

In this case, the IC sniffs the frame on MISO line. It considers the position of bit at 1 in the frame.

b15 is expected at 0, so b15 is in a relevant position and b15 in the SAF\_RESP\_MASK is set

b[14:13] expected 01 so b14 and b13 are set

b12 don't care so b12 is left at 0

b[11:10] expected 10so b11, b10 are set

b[9:0] are the data, not useful to identify which message has to be chosen, so they are left 0

| bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|     | 1  | 1  | 1  | 0  | 1  | 1  |   |   |   |   | ( | ) |   |   |   |   |

<sup>2.</sup> R = READ W = WRITE.

## 5.4.4 Response Target (MISO line)

Considering all the data that can pass on MISO line, the only one that has to be considered is the data that in the position defined in RESP MASK has the value defined in the RESP TARGET.

So:

in RESP MASK it is defined which bit to look at;

in RESP TARGET it is defined the expected value they have, coming from the sensors (MISO line)

This procedure is the definition of the filter of all the data exchanged: which bit to consider and which value they should have, sensor side.

\$B9 SAF\_RESP\_TARGET\_1 ÷ \$C5 SAF\_RESP\_TARGET\_13

## Table 33. \$B9 SAF\_RESP\_TARGET\_1

|                           | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9   | 8   | 7    | 6   | 5                | 4  | 3 | 2 | 1 | 0 |                         |
|---------------------------|-----|-----|----|----|----|----|----|----|----|----|----|-----|-----|-----|------|-----|------------------|----|---|---|---|---|-------------------------|
| \$B9<br>SAF_RESP_TARGET_1 | D   | w   | x  | x  | x  | x  |    |    |    |    | SA | \F_ | RE: | SP_ | _ TA | ARG | BET <sub>.</sub> | _x |   |   |   |   | cleared by<br>SSM_RESET |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

In the example SAF\_RESP\_TARGETx[15:0]:

| bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|     | 0  | 0  | 1  | Х  | 1  | 0  |   |   |   |   | ) | ( |   |   |   |   |

The SAF\_RESP\_TARGET indicates which values are expected for the bit selected in the SAF\_RESP\_MASK:

b15 = 0

b[14:13] = 01

b12 don't care  $\rightarrow x$ 

b[11:10] = 10

b[9:0] this field correspond to the data that are not known a priori 'x

The SAF\_DATA\_MASK indicates where the data bit are localized, in the frame received from the sensor and identified through SAF\_RESP\_MASK, SAF\_RESP\_TARGET

In this example data are supposed to be localized in position 9:0, so the correspondent bit b[9:0] = 1

SO[15:0] & SAF\_RESP\_MASKx[15:0] = SAF\_RESP\_TARGETx[15:0]

<sup>2.</sup> R = READ W = WRITE.

## 5.4.5 Data Mask (MISO line)

It is defined the position of the bit to be considered, inside the frame received from the sensor (MISO) to extract relevant sensor data from the response:

So:

\$CC SAF\_DATA\_MASK\_1 ÷ \$D8 SAF\_DATA\_MASK\_13

## Table 34. \$CC SAF\_DATA\_MASK\_1

|                         | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9   | 8   | 7   | 6   | 5   | 4 | 3 | 2 | 1 | 0 |                         |
|-------------------------|-----|-----|----|----|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|---|---|---|---|---|-------------------------|
| \$CC<br>SAF_DATA_MASK_1 | D   | w   | х  | х  | х  | x  |    |    |    |    | ;  | SAF | :_D | ATA | 4_N | 1AS | K_1 |   |   |   |   |   | cleared by<br>SSM_RESET |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

In the example SAF\_DATA\_MASKx[15:0]:

b[9:0] this field correspond to the position of the data

| bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|     | 0  | 0  | 0  | 0  | 0  | 0  |   |   |   |   | • | 1 |   |   |   |   |

Safing Threshold - specific value that sets the comparator limit for successful arming.

The integrated safing logic uses data from on-board and remote locations by decoding the various SPI communications between the interfaces and the main microcontroller.

Arming condition, required to be able to deploy, can be processed by an internal logic or external logic, according to SAFESEL bit[3], \$01 SYS CFG:

0 = internal safe engine

1 = external safe engine

Table 35. \$01 SYS\_CFG

|              | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3       | 2 | 1 | 0 |                                         |
|--------------|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---------|---|---|---|-----------------------------------------|
| \$01 SYS_CFG | -   | V   | 0  | 0  | 0  | 0  |    |    |    |    |    |    |   |   |   |   |   |   | SAFESEL |   |   |   | Updated by<br>SSM_RESET<br>or SPI write |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

<sup>2.</sup> R = READ W = WRITE.

<sup>2.</sup> R = READ W = WRITE.

# 5.5 SPI sensor data decoding (32 bit safing record mask)

Let's suppose to have the case where the 16bit sensor data are located across the first and second 16 bit words of the SPI sensor frame. In this case it is not possible to use the safing records equipped with 16 bit masks but one of the safing records 14-16 has to be used.

Despite the masks length, the sensor data is supposed to be always 16 bit maximum.

Supposing, for example, the sensor SPI frame is so organized:

14 bit acceleration data distributed between bit 10 and bit 23 of the SPI frame;

inside the 32 bit frame, data should be distributed as here indicated:

b[28:27] = channel selection, x or y; should 01 the codification for x channel

b[26]= parity bit

b[25:24] = codification data sensor field information (acceleration, self-test, error, etc.); should in the example b[25:24] =10 the codification for the acceleration data of sensor data field

b[23:6]= sensor data, split between 14 bit acceleration data [23:10] and 4 bit address b[9:6] (= 1010), in this example.

| bit | 31 | 30 | 29 | 28  | 27  | 26 | 25  | 24  | 23 | 22 | 21 | 20 | 19  | 18  | 17  | 16  | 15 | 14  | 13 | 12 | 11 | 10 | 9    | 8    | 7    | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|-----|-----|----|-----|-----|----|----|----|----|-----|-----|-----|-----|----|-----|----|----|----|----|------|------|------|------|---|---|---|---|---|---|
| SO  |    |    | 0  | CH1 | СН0 | Р  | ST1 | STO |    |    |    | AC | CCE | LEI | RAT | IOI | ۱D | ATA | ١. |    |    |    | ADD3 | ADD2 | ADD1 | ADD0 |   |   |   |   |   |   |

If the microcontroller request is (MOSI):

| bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| S   | Х  | Χ  | 0  | 0  | 1  | Х  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | Χ  | Χ  | Χ  | Χ  | Χ  | 0  | 0  | 0  | 1 | 0 | 1 | 0 | Χ | Х | Χ | Х | Χ | Х |

Acceleration data (14 bit, b[13:0]) are located in the sensor SO frame in the position b[23:10].

## 5.5.1 Request Mask (MOSI line)

Setting SAF\_REQ\_MASK[15:0] bit in SAF\_REQ\_MASK\_x, it is defined, inside the frame, the position of the bit to be considered in the data received.

Extraction of data is done putting in bitwise AND (&) the SAF\_REQ\_MASK with the data received.

SAF\_REQ\_MASK is applied on messages recorded from MOSI pin;

The device splits the first 16 MSB bit of the 32 bit frame received in the SAF\_REQ\_MASKx\_pt1[15:0] the other 16 LSB of the receiver frame in SAF\_REQ\_MASKx\_pt2[15:0]

\$8D SAF\_REQ\_MASK\_14\_pt1 ÷ \$92 SAF\_REQ\_MASK\_16\_pt2

## Table 36. \$8D SAF\_REQ\_MASK\_14\_pt1

|                             | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9  | 8   | 7   | 6   | 5   | 4  | 3 | 2 | 1 | 0 |                         |
|-----------------------------|-----|-----|----|----|----|----|----|----|----|----|----|------|----|-----|-----|-----|-----|----|---|---|---|---|-------------------------|
| \$8D<br>SAF_REQ_MASK_14_pt1 | D   | W   | x  | x  | x  | x  |    |    |    |    | SA | \F_I | RE | Q_N | ЛAS | SK_ | x_p | ti |   |   |   |   | cleared by<br>SSM_RESET |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

In the example SAF\_REQ\_MASKx\_pt1 [15:0], SAF\_REQ\_MASKx\_pt2 [15:0]:

|                                                       |    | 5  | SAF_ | REQ_ | MAS | Kx_l | ot1 [1 | 5:0] |    |    |    |    |    |    |    |    |
|-------------------------------------------------------|----|----|------|------|-----|------|--------|------|----|----|----|----|----|----|----|----|
| 16MSB of 32 bit frame                                 | 31 | 30 | 29   | 28   | 27  | 26   | 25     | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| SAF_REQ_MASKx_pt1 bit [15:0]                          | 15 | 14 | 13   | 12   | 11  | 10   | 9      | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SAF_REQ_MASKx_pt1                                     | 0  | 0  | 1    | 1    | 1   | 0    | 1      | 1    | 1  | 1  | 1  | 1  | 1  | 1  | 0  | 0  |
| SAF_REQ_MASKx_pt1   0   0   1   1   1   0   1   1   1 |    |    |      |      |     |      |        |      |    |    |    |    |    |    |    |    |
| 16LSB of 32 bit frame                                 | 15 | 14 | 13   | 12   | 11  | 10   | 9      | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SAF_REQ_MASKx_pt2 bit [15:0]                          | 15 | 14 | 13   | 12   | 11  | 10   | 9      | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SAF_REQ_MASKx_pt2                                     | 0  | 0  | 0    | 1    | 1   | 1    | 1      | 1    | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  |

#### SAF\_REQ\_MASKx\_pt1 [15:0]:

b[13] = 1 correspondent bit is expected to be 0

b[12:11] = 1, in correspondence of these bit positions, the bit identifying channel are localized

b[9:8] = 1, in correspondence of these bit positions, the bit identifying sensor signal are localized (acceleration, self-test..)

b[7:2] = 1 correspondent bit is expected to be 0

b[10], b[1:0] = 0 in correspondence of these bit positions, the bit identifying unknown bit a priori are localized.

<sup>2.</sup> R = READ W = WRITE

## SAF\_REQ\_MASKx\_pt2 [15:0]:

b[15:13] = 0 in correspondence of these bits positions, the bit identifying unknown bit a priori are localized.

b[12:10] = 1 correspondent bit is expected to be 0

b[9:6] = 1, in correspondence of these bits positions, the bit identifying sensor address are localized.

b[5:0] = 0 in correspondence of these bit positions, the bit identifying unknown bit a priori are localized.

## 5.5.2 Request Target (MOSI line)

Considering bit selected through SAF\_REQ\_MASKx\_pti, the value they have to assume is indicated REQUEST TARGET.

So:

in SAF\_REQ\_MASK\_pti it is defined which bit position to look at;

the expected values of the bit, which are in the positions indicated by SAF\_REQ\_MASK\_pti, are defined in SAF\_REQ\_TARGET\_pti.

This procedure is the definition of the filter of all the data exchanged: which bit to consider and which value they should have.

\$A0 SAF\_REQ\_TARGET\_14\_pt1 ÷ \$A5 SAF\_REQ\_TARGET\_16\_pt2

Table 37. \$A0 SAF\_REQ\_TARGET\_14\_pt1

|                               | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8   | 7   | 6   | 5   | 4  | 3 | 2 | 1 | 0 |                         |
|-------------------------------|-----|-----|----|----|----|----|----|----|----|----|----|-----|----|-----|-----|-----|-----|----|---|---|---|---|-------------------------|
| \$A0<br>SAF_REQ_TARGET_14_pt1 | D   | w   | x  | x  | х  | х  |    |    |    |    | SA | ۹F_ | RE | :Q_ | TAI | RGI | ET_ | _x |   |   |   |   | cleared by<br>SSM_RESET |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / -= ALL STATES(I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

In the example, SAF\_REQ\_TARGETx\_pt1[15:0], SAF\_REQ\_MASKx\_pt2[15:0]:

| SAF_REQ_TARGETx_pt1 [15:0]                                           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
|----------------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
| 16MSB of 32 bit frame 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 1 |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 16 |   |
| SAF_REQ_TARGETx_pt1 bit [15:0]                                       | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| SAF_REQ_TARGETx_pt1                                                  | 0  | 0  | 0  | 0  | 1  | 0  | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0 |
| SAF_REQ_TARGETx_pt2 [15:0]                                           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
| 16LSB of 32 bit frame                                                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| SAF_REQ_TARGETx_pt2 bit [15:0]                                       | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| SAF_REQ_TARGETx_pt2                                                  | 0  | 0  | 0  | 0  | 0  | 0  | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0  | 0 |



<sup>2.</sup> R = READ W = WRITE.

## SAF\_REQ\_TARGETx\_pt1 [15:0]:

b[13] = 0, this bit is expected to be 0

b[12:11] = 01 they are expected to be 01 identifying in the example x axis data

b[9:8] = 10 having supposed this combination identifies that data received from sensor are the acceleration

b[7:2] these bits are expected to be 0

## SAF\_REQ\_TARGETx\_pt2 [15:0]:

b[12:10] these bits are expected to be 0

b[9:6] = 1010 being selected the sensor with this address.

SI[31:16] & SAF\_REQ\_MASKx\_pt1[15:0] = SAF\_REQ\_TARGETx\_pt1[15:0]

SI[15:0] & SAF\_REQ\_MASKx\_pt2[15:0] = SAF\_REQ\_TARGETx\_pt2[15:0]

## 5.5.3 Response Mask (MISO line)

To identify the sensor response, it is defined, inside the frame received from the sensor (MISO), the position of those bit to be considered.

This is done setting the bit, in SAF\_RESP\_MASK\_x\_pti, located in the position of the bit to be considered.

\$B3 SAF\_RESP\_MASK\_14\_pt1 ÷ \$B8 SAF\_RESP\_MASK\_16\_pt2

Table 38. \$B3 SAF RESP MASK 14 pt1

|                              | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9   | 8   | 7  | 6   | 5   | 4 | 3 | 2 | 1 | 0 |                         |
|------------------------------|-----|-----|----|----|----|----|----|----|----|----|----|------|-----|-----|----|-----|-----|---|---|---|---|---|-------------------------|
| \$B3<br>SAF_RESP_MASK_14_pt1 | D   | w   | x  | x  | х  | x  |    |    |    |    | SA | .F_F | RES | SP_ | _M | ASI | K_> | ( |   |   |   |   | cleared by<br>SSM_RESET |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

In the example SAF\_RESP\_MASKx\_pt1[15:0], SAF\_RESP\_MASKx\_pt2[15:0]

| SAF_RESP_MASKx_pt1 [15:0]                      |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------------------------------------------------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 16MSB of 32 bit frame                          | 31     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| SAF_RESP_MASKx_pt1 bit [15:0] -<br>16MSB frame | 15     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SAF_RESP_MASKx_pt1                             | (x_pt1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| SAF_RESP_MASKx_pt2 [15:0]                      |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 16LSB of 32 bit frame                          | 15     | 14 | 13 | 12 | 11 | 10 | တ  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SAF_RESP_MASKx_pt2 bit [15:0] - 16LSB frame    | 15     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SAF_REQ_TARGETx_pt2                            |        |    | (  | )  |    |    | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  |

<sup>2.</sup> R = READ W = WRITE.

SAF\_RESP\_MASKx\_pti allows choosing one message with respect to all that runs on SPI

In this case, the IC sniffs the frame on MISO line and considers, in the 32 bit frame, the position of bit at 1.

b29 in the sensor data frame corresponds to b13 in SAF\_RESP\_MASKx\_pt1. It is expected to be 0. Its position is relevant so it is set in SAF\_RESP\_MASKx\_pt1.

b[28:27] in the sensor data frame correspond to b[12:11] in SAF\_RESP\_MASKx\_pt1. They are expected to be 01. Their position is relevant so they are set in SAF\_RESP\_MASKx\_pt1.

b26 in the sensor data frame corresponds to b10 in SAF\_RESP\_MASKx\_pt1. It is the sensor parity bit. It is not relevant so it is left 0.

b[25:24] in the sensor data frame correspond to b[9:8] in SAF\_RESP\_MASKx\_pt1. They are expected to be 10. Their position is relevant so they are set in SAF\_RESP\_MASKx\_pt1.

b[23:16] in the sensor data frame correspond to b[7:0] in SAF\_RESP\_MASKx\_pt1. This is data field; data value is not known a priori, so these bits are left 0.

b[15:10] in the sensor data frame correspond to b[15:10] in SAF\_RESP\_MASKx\_pt2. This is data field; data value is not known a priori, so these bits are left 0.

b[9:6] in the sensor data frame correspond to b[9:6] in SAF\_RESP\_MASKx\_pt2. These bits represent the sensor's address so they are set.

## 5.5.4 Response Target (MISO line)

Considering all the data that can pass on MISO line, the only one that has to be considered is the data that in the position defined in RESP MASK has the value defined in the RESP TARGET.

So:

in RESP MASK it is defined which bit to look at;

in RESP TARGET it is defined the expected value they have, coming from the sensors (MISO line)

This procedure defines a filter for all the data exchanged: which bit to consider and which value they correspond, sensor side.

\$C6 SAF RESP TARGET 14 pt1 ÷ \$CB SAF RESP TARGET 16 pt2

# \$C6 SAF\_RESP\_TARGET\_14\_pt1 D W X X X X SAF\_RESP\_TARGET\_X Cleared by SSM\_RESET

Table 39. \$C6 SAF RESP TARGET 14 pt1

- 1. I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.

The SAF\_RESP\_TARGETx\_pti indicates which values are expected for the bit selected in the SAF\_RESP\_MASKx\_pti.

70/106 DocID030428 Rev 1

Following the example, SAF\_RESP\_TARGETx\_pt1[15:0], SAF\_TARGET\_MASKx\_pt2[15:0]

| SAF_RESP_TARGETx_pt1 [15:0]                   |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 16MSB of 32 bit frame                         | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| SAF_RESP_TARGETx_pt1 bit [15:0] - 16MSB frame | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SAF_RESP_TARGETx_pt1                          | 0 0 0 1 0 1 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| SAF_RESP_TARGETx_pt2 [15:0]                   |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 16LSB of 32 bit frame                         | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SAF_RESP_TARGETx_pt2 bit [15:0] - 16LSB frame | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SAF_RESP_TARGETx_pt2                          | 0               |    |    |    |    |    |    | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

b[13] in SAF\_RESP\_TARGETx\_pt1 (that is b[29] in the sensor data frame) is expected to be 0.

b[12:11] in SAF\_RESP\_TARGETx\_pt1 (that are b[28:27] in the sensor data frame) are expected to be 01

b[9:8] in SAF\_RESP\_TARGETx\_pt1 (that are b[25:24] in the sensor data frame) are expected to be 10.

b[9:6] in SAF\_RESP\_TARGETx\_pt2 (that are b[9:6] in the sensor data frame) depend on the sensor's address expected to be 1010.

SAF\_RESP\_MASKx\_pti indicates where sensor data bit are localized, in the frame received from the sensor;

in SAF\_RESP\_TARGETx\_pti it is defined the expected value for the bit with the aim to select the data inside all the frame exchanged between the device and the microcontroller.

SO[31:16] & SAF\_RESP\_MASKx\_pt1[15:0] = SAF\_RESP\_TARGETx\_pt1[15:0] SO[15:0] & SAF\_RESP\_MASKx\_pt2[15:0] = SAF\_RESP\_TARGETx\_pt2[15:0]

## 5.5.5 Data Mask (MISO line)

Once identified the channel sensor direction (x or y), the kind of the data (acceleration, self-test, error) through SAF\_REQ\_MASKx\_pti, SAF\_REQ\_TARGETx\_pti, SAF\_RESP\_MASKx\_pti and SAF\_RESP\_TARGETx\_pti, it is required to extract acceleration data, through SAF\_DATA\_MASKx\_pti.

SAF\_DATA\_MASKx\_pti define the position of the bit to be considered, inside the frame received from the sensor (MISO) to extract the sensor data from the response:

\$D9 SAF\_DATA\_MASK\_14\_pt1 ÷ \$DE SAF\_DATA\_MASK\_16\_pt2

## Table 40. \$D9 SAF\_DATA\_MASK\_14\_pt1

|                              | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9   | 8   | 7   | 6   | 5   | 4 | 3 | 2 | 1 | 0 |                         |
|------------------------------|-----|-----|----|----|----|----|----|----|----|----|----|------|-----|-----|-----|-----|-----|---|---|---|---|---|-------------------------|
| \$D9<br>SAF_DATA_MASK_14_pt1 | D   | w   | x  | x  | х  | х  |    |    |    |    | SA | .F_[ | DAT | ΓA_ | _M/ | ASŁ | <_1 |   |   |   |   |   | cleared by<br>SSM_RESET |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / -= ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

Following the example, SAF\_DATA\_MASKx\_pt1[15:0], SAF\_DATA\_MASKx\_pt2[15:0].

| SAF_DATA_MASKx_pt1 [15:0]                   |                |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
|---------------------------------------------|----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
|                                             |                |    |    |    |    |    |   |   |   |   |   |   |   |   | 16 |   |
| SAF_DATA_MASKx_pt1 bit [15:0] - 16MSB frame | 15             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| SAF_ DATA_MASKx_pt1                         | DATA_MASKx_pt1 |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
| SAF_DATA_MASKx_pt2 [15:0]                   |                |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
| 16LSB of 32 bit frame                       |                |    |    |    |    |    |   |   |   |   |   |   | 1 | 0 |    |   |
| SAF_DATA_MASKx_pt2 bit [15:0] - 16LSB frame | 15             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| SAF_DATA_MASKTx_pt2                         |                |    |    | 1  |    |    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0 |

b[7:0] in SAF\_DATA\_MASKx\_pt1 (that are b[23:16] in the sensor data frame) localize the field of sensor data - MSB part.

b[15:10] in SAF\_DATA\_MASKx\_pt2 (that are b[15:10] in the sensor data frame) localize the field of sensor data - LSB part.

Safing Threshold - specific value that sets the comparator limit for successful arming.

<sup>2.</sup> R = READ W = WRITE.

AN5023 Arming

# 5.6 Trigonometry for crash sensor orientation

# 5.6.1 Comb (Combined Data)

This command allows, performing mathematic elaboration as sum or difference between accelerations read from different sensors, to elaborate the direction of the acceleration detected from x-y axis to have an on-axis response. The direction depends on the sensor orientation inside the system.

Combine function (COMB) is enabled through COMB bit, bit 10 in SAF\_CONTROL\_x registers, x=1÷12 (address EF÷FA).

When the combine function is enabled, the elaboration, being x=1, 3, 5, 7, 9, 11, is:

- Safing record pairs x, x+1 (1, 2 / 3, 4 / 5, 6 / 7, 8 / 9, 10 / 11, 12)
- Safing record (x) = data(x) + data (x+1)
- Safing record (x+1) = data(x) data (x+1)

Since this elaboration is performed using two safing records, the elaboration itself is performed only after that the two safing records have been captured (CC\_x=1).

As an example, consider the case of an on-board dual axis sensor which is offset 45 degrees from the center, the IC allows vector addition/subtraction to refer the sensor data to the vehicle axis.

Here below it is shown how to refer the data caught by the sensors, referred to their axis orientation, to the axis LONG and LAT of the vehicle, through simple sum or difference of sensor data, with the aim of managing the ARMING process.



Figure 34. Sensor's axis and vehicle's axis correlation

Arming AN5023

$$LONG = X^* \cos(\theta) + Y^* \cos(\theta + 90^\circ)$$

$$LAT = X^* \cos(\theta + 90) + Y \cos(\theta + 180)$$
if
$$\theta = 45^\circ$$

$$LONG = X^* \frac{\sqrt{2}}{2} - Y^* \frac{\sqrt{2}}{2} = \frac{\sqrt{2}}{2}(X - Y)$$

$$LAT = -X^* \frac{\sqrt{2}}{2} - Y \frac{\sqrt{2}}{2} = -\frac{\sqrt{2}}{2}(X + Y)$$

GAPGPS02889

Thresholds are referred to LONG and LAT reference system;

Data caught from sensor are referred to X and Y axis. These axis are rotated with respect to LONG and LAT axis, see *Figure 34*.

The thresholds (TH\_LONG and TH\_LAT thresholds) must consider the sensor direction with respect to the vehicle axis, so the trigonometric parameters ( $\theta$ ) are known and included in the thresholds:

$$|X-Y| > TH^* \frac{2}{\sqrt{2}} = TH\_LONG$$
  
 $|X+Y| > TH^* \frac{2}{\sqrt{2}} = TH\_LAT$ 

AN5023 Deployment

# 6 Deployment

L9680 is equipped with 12 independent loops, each of them composed by a low and high side, which can deploy at the same time or according to a given sequence.

As for the low end, dedicated ground connection for a couple of loops, SGxy, is connected to GNDSUB through a diode to guarantee the firing in case of SGxy lost.

In case the low side SRx is shorted to ground, the deployment, if requested, is guaranteed to succeed.

In any case, SSxy voltage has to be lower than 25V.

Both high side and low side are equipped with a passive turn-off to guarantee that they are always in off state except when the deployment has to take place.

# 6.1 Deployment requirement

Deployment features are deploy current, deploy time and deployment expiration time;

deployment expiration time is the duration time in which the deploy command remains valid, once it is received, waiting for the ARMING signal asserted; it is the correspondent of DWELL time:

These parameters are set in DCR\_x registers:

(1) (2) 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 2 =0.064 ms/coun b[11:6] |t\*depl time ≤ 4.032 ms Depl\_expire\_time Deploy\_current 00, 11 not used 01 1.75 A min b[5:4] \$06 DCR 0: (I) W 0 0 0 0 Χ X Х Χ Χ Deploy time \$11 DCR B 10 1.2 A min 00 500 ms 01 250 ms b[3:2] 10 125 ms 11 0 ms

Table 41. \$06 DCR\_0: \$11 DCR\_B deploy parameters

The Deploy Time field allows the device deploying for a configurable time 4.032 ms max (64  $\mu$ s step), whereas in the low end the deploy time can be chosen between three fixed values, 0.5 ms, 0.7 ms, 0.7 ms, 0.7 ms.

In the low end, L9678, there is the inhibition of the combination 1.75 A, 2 ms; in the L9680 device, this constraint is no more effective, so it is under user's responsibility to prevent excessive thermal heating in the squib driver section by setting the deploy parameters carefully.

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
(I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

<sup>2.</sup> R = READ W = WRITE.

Deployment AN5023

In case the deployment minimum current is set at 1.75 A, it is recommended

 for deployment times between 0.7ms and 2ms, the voltage drop across the pins is limited to 17 V max

for deployment times up to 3.2 ms, the voltage drop across the pins is limited to 15 V max.

In case the deployment minimum current is set at 1.2 A, it is recommended

 for deployment times between 2 ms and 3.2 ms, the voltage drop across the pins is limited to 22 V max.

The voltage values above indicated (15V, 17V, 22V), relevant for long deploy time, depend on the squib resistance value being the voltage across the high side power (SSxy - SFx(y)) roughly VSF-RSQUIB\*I.

Being the L9680 flexible in deploy parameters configuration, the load in the loop can be a squib -RSQUIB- or can be another component, as for example a pre-tender, whose parameters are slightly different from the squib itself, but it can be anyway driven by the L9680 itself.

The parameters in each DCR\_x registers have to be confirmed at least the first time the device has to deploy, even in case they are left at their default value; the deployment does not occur otherwise.

Status of each loop is monitored in deployment status register, one for each channel:

(1) (2) 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 2 1 0 4 3 0 depl not successful b[15] 1 dep successful DEP\_CHX\_EXP\_TIME 0 depl not in progress b[14] 1 depl in progress DCRXERR CHXSTAT CHXDSX \$13 DSR 0: 0 depl conf accepted 0 0 0 R 0 0 0 0 0 0 0 \$1E DSR B and stored b[12] |1 depl conf change not accepted because deploy is in progress. b[5:0] 8 ms/count

Table 42. \$13 DSR\_0: \$1E DSR\_B

Once deploy parameters have been set, it is required to assign the channels to deployment loops. This allows deploying different channels basing on the arming result. Arming results are in turn correlated to the acceleration detected and then to the collision happened.

The combination channels-deployment loop is fixed via SPI considering that external and internal arming are different.

In case of internal safing engine, four deployment loops are available and defined in registers \$6E: \$71;

577

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

<sup>2.</sup> R = READ W = WRITE.

AN5023 Deployment

In case of the external safing engine, three deployment loops are available, each of them associated to ARM1, ARM2, ARM3 pin (acting as FENH) value being ARM4 common for all (acting as FENL).

For deployment loop it is meant a group of different deployment channels related to the same ARMx signal.

|  | Table 43. \$6E LOOP | MATR | <b>ARM1: \$</b> | 71 LOOP | MATR | ARM4 |
|--|---------------------|------|-----------------|---------|------|------|
|--|---------------------|------|-----------------|---------|------|------|

|                                                                                                                | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11      | 10  | 9       | 8       | 7       | 6 | 5       | 4       | 3       | 2       | 1       | 0  |                         |                                                                  |
|----------------------------------------------------------------------------------------------------------------|-----|-----|----|----|----|----|----|----|----|----|---------|-----|---------|---------|---------|---|---------|---------|---------|---------|---------|----|-------------------------|------------------------------------------------------------------|
| \$6E LOOP_MATR_ARM1<br>\$6F LOOP_MATR_ARM2<br>\$70 LOOP_MATR_ARM3<br>( <sup>(3)</sup> ) \$71<br>LOOP_MATR_ARM4 | D   | W   | 1  | -  | 1  | 1  | x  | x  | ×  | x  | ARMx LB | l ⊐ | ARMx L9 | ARMx L8 | ARMx_L7 | ᆜ | ARMx L5 | ARMx L4 | ARMx L3 | ARMx_L2 | ARMx L1 | /x | b[i]<br>i=11:0<br>x=1:4 | 0 ARMx not<br>associate<br>to Li<br>1 ARMx<br>associate<br>to Li |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

3. This register is meaningless in case of external safing engine.

Once fixed the deploy parameters, in order to satisfy a deploy request, the IC has to move in SAFING state or SCRAP state.

Both states are driven by specific SPI commands; SAFING state corresponds to the normal IC operation whereas SCRAP state corresponds to the operation at final disposal of the IC.

Once sent the command to move into SAFING or SCRAP state, the verification of the IC's status is readable into \$04 SYS\_STATE register.

The SPI commands just mentioned are:

Table 44. \$30 SCRAP state, \$31 SAFING state, \$04 SYS\_STATE

|                      | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9         | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0 |         |                         |
|----------------------|-----|-----|----|----|----|----|----|----|----|----|----|----|-----------|-----|---|---|---|---|---|---|------------|---|---------|-------------------------|
| \$30 SCRAP<br>STATE  | D   | W   | 0  | 0  | 0  | 0  |    |    |    |    |    |    | \$3       | 353 | 5 |   |   |   |   |   |            |   | SCRAP   | state command           |
| \$31 SAFING<br>STATE | D   | W   | 0  | 0  | 0  | 0  |    |    |    |    |    |    | \$A       | CA  | C |   |   |   |   |   |            |   | SAFING  | state command           |
|                      |     |     |    |    |    |    |    |    |    |    |    | I. | SIAIE     |     |   |   |   |   |   |   | STATE      |   | b[10:8] | 010=SAFING<br>011=SCRAP |
| \$04<br>SYS_STATE    | 1   | R   |    |    |    |    |    |    |    |    |    | į  | OPEK_CIL_ |     |   |   |   |   |   |   | POWER_CTL_ |   | b[2:0]  | 010=RUN                 |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

In order to be able to deploy, the arming signals have to be serviced;



<sup>2.</sup> R = READ W = WRITE

<sup>2.</sup> R = READ W = WRITE.

Deployment AN5023

their state is readable in \$6A ARM\_STATE register:

Table 45. \$6A ARM\_STATE

|                   | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9        | 8              | 7             | 6         | 5        | 4        | 3        | 2        | 1 | 0 |                                                 |                                                                                         |
|-------------------|-----|-----|----|----|----|----|----|----|----|----|----|----|----------|----------------|---------------|-----------|----------|----------|----------|----------|---|---|-------------------------------------------------|-----------------------------------------------------------------------------------------|
| \$6A<br>ARM_STATE | ı   | R   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | PSINHINT | PSINH_EXP_TIME | ACL_PIN_STATE | ACL_VALID | ARMINT_4 | ARMINT_3 | ARMINT_2 | ARMINT_1 | 0 | 0 | b[5],<br>b[4],<br>b[3], b[2]<br>ARMINT<br>_4ARM | Internal safing engine: Result of safing engine External safing engine: Eco of ARMx pin |

- 1. I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / -= ALL STATES(I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.

If the internal safing machine has been selected, the four relevant bit ARMINT\_4 ... ARMINT\_1 indicate the internal safing engine result, if the external safing engine has been selected the same four bits are the echo of the four pins ARMx.

Deployment has to be enabled via SPI, \$25 SPIDEPEN because the default value is disabled:

Table 46. \$25 SPIDEPEN

|                  | (1)     | (2)     | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12  | 11  | 10   | 9    | 8      | 7   | 6   | 5   | 4   | 3   | 2    | 1 | 0 |                                               |
|------------------|---------|---------|----|----|----|----|----|----|-----|-----|-----|------|------|--------|-----|-----|-----|-----|-----|------|---|---|-----------------------------------------------|
| \$25<br>SPIDEPEN | S,<br>A | W/<br>R | -  | -  | -  | -  |    | [  | DEF | PEN | I_W | /R[1 | 15:0 | )] / [ | DEF | PEN | I_S | TAT | E[1 | 15:0 | ] |   | \$0FF0 – DEP DISABLED<br>\$F00F – DEP ENABLED |

- I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES
   (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.

Deployment command request has to be received by the IC, \$12 DEPCOM.

Once the deployment command has been received, the deploy time is elapsed, and deploy success bit is set (CHxDSX see below), deployment enable toggles into DEP DISABLED;

The next deploy requires the DEPEN reconfigured again as ENABLED; this feature has to be considered in case of multiple deployment, after each of them, before the next deployment the correspondent bit DEPEN has to be set again:

AN5023 Deployment

Table 47. \$12 DEPDOM, \$25 SPIDEPEN

|                  | (1) | (2)     | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11        | 10        | 9         | 8         | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |                          |                                                                                                                        |
|------------------|-----|---------|----|----|----|----|----|----|----|----|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--------------------------|------------------------------------------------------------------------------------------------------------------------|
| \$12<br>DEPCOM   |     | w       | -  | -  | 1  |    | 0  | 0  | 0  | 0  | CHBDEPREQ | CHADEPREQ | CH9DEPREQ | CH8DEPREQ | CH7DEPREQ | CH6DEPREQ | CH5DEPREQ | CH4DEPREQ | CH3DEPREQ | CH2DEPREQ | CH1DEPREQ | CHODEPREQ | b[11:0]<br>CHxDEP<br>REQ | 0 no change to<br>dep ch x<br>1 if in ARMING<br>or SAFING,<br>clear and start<br>expiration time<br>and<br>DEPLOY_ENAB |
| \$12<br>DEPCOM   |     | R       | -  | -  | ı  |    | 0  | 0  | 0  | 0  | CHBDEP    | CHADEP    | CH9DEP    | CH8DEP    | CH7DEP    | CH6DEP    | CH5DEP    | CH4DEP    | CH3DEP    | CH2DEP    | CH1DEP    | CHODEP    | b[11:0]<br>CHxDEP        | 1 expiration<br>timer enabled,<br>DEPCOM still<br>valid<br>0 expiration<br>timer disabled,<br>DEPCOM no<br>more valid  |
| \$25<br>SPIDEPEN |     | W/<br>R | _  | _  |    | -  |    |    |    |    |           | DEF       | PEN       | _S        | TAT       | E[1       | 5:0       | ]         |           |           |           |           | \$0FF0 — I               | DEP DISABLED                                                                                                           |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

Deployment status of each channel is readable in \$13 DSR\_0 ÷ \$1E DSR\_B registers:

Table 48. \$13 DSR\_0: \$1E DSR\_B

|             | (1) | (2) |    |    | I  | Ι  |       |         |    |         | Ι  | Ι  |   | _ | Ė |   | Τ. | Τ.  | Ŧ.  |           | Τ. | Ι_ |        |                                                                                                            |
|-------------|-----|-----|----|----|----|----|-------|---------|----|---------|----|----|---|---|---|---|----|-----|-----|-----------|----|----|--------|------------------------------------------------------------------------------------------------------------|
|             | (1) | (2) | 19 | 18 | 17 | 16 | 15    | 14      | 13 | 12      | 11 | 10 | 9 | 8 | 7 | 6 | !  | 5 4 | 1 3 | 3 2       | 1  | 0  |        |                                                                                                            |
|             |     |     |    |    |    |    |       |         |    |         |    |    |   |   |   |   |    |     |     |           |    |    | b[15]  | 0 depl not successful<br>1 dep successful                                                                  |
| \$13 DSR_0: |     | R   | 0  | 0  | 0  | 0  | CHxDS | CHxSTAT | 0  | DCRXERR | 0  | 0  | 0 | 0 | 0 | 0 |    |     |     | _EXP_TIME |    |    | b[14]  | 0 depl not in progress<br>1 depl in progress                                                               |
| \$1E DSR_B  |     |     |    |    |    |    | CH    | CHX     |    | DCR     |    |    |   |   |   |   |    |     |     | DEP_CHX_  |    |    | b[12]  | 0 depl conf accepted<br>and stored<br>1 depl conf change not<br>accepted because<br>deploy is in progress. |
|             |     |     |    |    |    |    |       |         |    |         |    |    |   |   |   |   |    |     |     |           |    |    | b[5:0] | 8 ms/count                                                                                                 |

I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES
 (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.

<sup>2.</sup> R = READ W = WRITE.



<sup>2.</sup> R = READ W = WRITE.

Deployment AN5023

Each High Side (SFx) has a current comparator to indicate when the current flowing through is greater than the deployment current threshold (ITHDEPL=90%IDEPLx) and for each channel there is a timer (Current\_Mon\_Timer) that measures, with 16us resolution, how long the current is at high level. This parameter is considered useful for the microcontroller to identify if the deployment has been effective or not.

During a deploy event, if the current falls momentarily below the threshold, the timer stops (timer pause), and continues to count as the current turns high.

Current\_Mon\_Timer is refreshed upon read or when a new DEPCOM command on the channel is received . For this reason, the microcontroller reads the data after the deployment event and before a new deployment command. The current measurement stops at the end of the deployment time.



Figure 35. Current measurement during deploy

AN5023 Deployment

|                                     | (1) | (2) | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12           | 11 | 10 | 9 | 8  | 7  | 6 | 5 | 4 | 3           | 2 | 1 | 0  |                                                                                                                                                        |
|-------------------------------------|-----|-----|----|----|----|----|----|----|----|--------------|----|----|---|----|----|---|---|---|-------------|---|---|----|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| \$1F<br>DCMTS01:<br>\$24<br>DCMTSAB |     | R   | 0  | 0  | 0  | 0  | CU |    |    | Г М(<br>, 3, |    |    |   | ME | CU |   |   |   | ONI<br>4, 6 |   |   | ME | b[15:8] current monitor time y = 1, 3, 5, 7, 9, B b[7:0] current monitor time x = 0, 2, 4, 6, 8, A 16µs increment while Deploy_curr> monitor threshold |

Table 49. \$1F DCMTS\_01 ÷ \$24 DCMTS\_AB

- 1. I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / = ALL STATES (I)=no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING.
- 2. R = READ W = WRITE.

Once the deployment has started, it can be interrupted by

- over-current in the low side
- GND loss
- SSM reset
- End of deployment time

Successful deploy event is reported in GSW, in DEPOK bit. Such a flag is the "OR" of the eventual deployment success of all the twelve channels.

| MISO BIT | 31     | 30    | 29    | 28       | 27      | 26       | 25  | 24       | 23       | 22      | 21      |
|----------|--------|-------|-------|----------|---------|----------|-----|----------|----------|---------|---------|
| MISO     | SPIFLT | DEPOK | RSFLT | wdtdis_s | ERSTATE | POWERFLT | FLT | CONVRDY2 | CONVRDY1 | ERR_WID | ERR_RID |
| GSW BIT  | 10     | 9     | 8     | 7        | 6       | 5        | 4   | 3        | 2        | 1       | 0       |

### Table 50. DEPOK in GSW

| GSW | MISO b[30] DEPOK = GSW b[9]                                              |
|-----|--------------------------------------------------------------------------|
|     | 0 = all DSR_x / CHxDS bit are = 0 (no deployment success on all channel) |
|     | 1 = at least a deployment successful on the channels.                    |

In case the deploy success = 1, this doesn't mean that the current is really passed through the squib for the programmed time. This bit means only that no inhibition of deployment has happened. The real evaluation about the deployment is through the channel current monitor time,  $1F DCMTSO1 \div 24 DCMTSAB$  registers.

In case of a short to ground of the Low Side during the deployment, the current is limited by the High Side avoiding the device's damage. The same protection is available if an open load condition happens, followed by a short to ground of the Low Side.

channel per channel

Deployment AN5023

# 6.2 Deployment driver protection

In order to avoid damage the IC due to eventual free-wheeling, two protections are implemented.

- 1. after a deployment, once the High Side is switched off, the low side is kept on for  $t_{DEL\ SD\ LS}$  (50 µs min) in order to allow fly-back.
- 2. once low side is switched off, a protection against the overvoltage through a clamp structure is implemented.

On the Low Side there is a current limitation and overcurrent protection circuit that attends limiting the current at ILIM\_SRx avoiding, in case of pin short to battery, any damage. If the malfunction lasts over  $t_{\text{FLT\_ILIM\_LS}}$  (100  $\mu$ s typ) the whole channel (High and Low Side) is switched off until a new deployment command, via SPI\_DEPEN occurs.

The squib driver can stand the short to ground of the pins during the deployment, because the high side current is limited by the high side itself.

Squib driver can also manage the case of SR short to ground after an open circuit, being it able to detect the open circuit condition and then limiting the current overshoot as the open circuit disappears.

In case of squib's intermittence during deployment phase, current limitation is ensured by the Low Side current limitation,  $I_{LIM\_SRx}.$  If the condition lasts longer than  $T_{FLT\_OS\_LS}$  the High Side is switched off for  $t_{OFF\_OS\_HS}$  and then on again.

This allows distinguish Open Load and Low Side short to battery cases and then properly manage them.

# 6.3 Deployment driver example

It is reported in this section an example of the set-up and SPI sequence implemented to deploy.

It has been chosen the external safing engine (an example of internal safing engine is described in the low level device's application note) so organized:

# 6.3.1 LOOP MATRIX ARMx:

ARM1 deployment loops 0, 1, 2, 3
ARM2 deployment loops 4, 5, 6, 7
ARM3 deployment loops 8, 9, A, B
ARM4 referred to all the low sides

ARM1=high deployment loops 0, 1, 2, 3 armed ARM2=ARM3=low deployment loops 4:B NOT armed

ARM4=low all the low side armed

82/106 DocID030428 Rev 1

# [[5]

# 6.3.2 Deployment configuration channel

deployment loops 0, 2, 4, 6, 8, A

 $I_{depl}$  = 1.75 A, deply time max 500ms, deploy time = 7  $\leftrightarrow$  448  $\mu s$ 

deployment loops 1, 3, 5, 7, 9, B

 $I_{depl}$  = 1.2 A, deply time max 500ms, deploy time = 7  $\leftrightarrow$  448  $\mu s$ 

# Table 51. Example of SPI message to deploy

| Register       | (1) | (2) | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|-----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| \$01 SYS_CFG   | ı   | W   | 0  | х  | 0  | 0  | 1  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | b[15]: 0 "auto off" off ISRC&DCS reg after meas def. b[13]: 0 hi curr overcurrent detect for syncbst satbuck vccbuck def b[12]: 0 ERBST disabled in ER state def b[11]: 1 PSINH external eng mode def. b[10]: 0 short time high lev squib diag def. b[9]:0 short time def. b[8,7]: 8 sample DC-squib-temp measure def. b[6,5]: 00 4 sample def b[4]=0 passenger inhibit current def b[3]=1 external safing eng b[2]=0 VSF=20V def. b[1]=0 syncbst=12V, satbuck=7.2v rsux=6.1 def. b[0]=1 timeout disabled |
| \$04 SYS_STATE | -   | R   |    |    |    |    |    | 0  | 0 | 0 |   |   |   |   |   | 0 | 1 | 0 | b[10:8]: 000 =INIT<br>b[2:0]: 010=RUN                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2C WD_STATE    | -   | R   |    | 1  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | b[14:11] WD1 ERR CNT b[10:8] WD1STATE 000 init 001 run 010 test 011 reset 100 override b[7:4] WD2 ERR CNT                                                                                                                                                                                                                                                                                                                                                                                                 |

DocID030428 Rev 1

Deployment

| Table 51. Example of SPI message to deplo | ov (continued |
|-------------------------------------------|---------------|
|-------------------------------------------|---------------|

| Register              | (1) | (2) | 15 | 14 | 13 | 12   | 11   |   |   |   | 7 |   |   | 4    |      | Ì  | 1 | 0 |                                                                                                                               |
|-----------------------|-----|-----|----|----|----|------|------|---|---|---|---|---|---|------|------|----|---|---|-------------------------------------------------------------------------------------------------------------------------------|
| Register  2C WD_STATE | -   | R   | 15 | 1  | 0  | 0    | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 0  | 0 | 0 | b[3:0] WD2STATE  0000 init  0001 override  0010 initseed  0011 run  0100 test  0101 qual  0110 lock  01111 stopping 1000 stop |
| \$35 WD_TEST          | -   | W   |    |    | W  | /D1_ | TEST | - |   |   |   |   | W | 'D2_ | _TES | ST |   |   | 1001 reset  b[15:8]: \$3C b[7:0]: \$C3                                                                                        |
| \$2C WD_STATE         | _   | R   | 1  | 0  | 0  | 0    | 0    | 1 | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 0  | 0 | 1 | b[14:11] WD1 ERR CNT b[10:8] WD1STATE 100 override                                                                            |
| \$20 WB_0 I/ME        |     |     | '  |    |    |      |      | ' |   |   |   |   |   | Ü    |      |    |   | ' | b[7:4] WD2 ERR CNT<br>b[3:0] WD2STATE<br>0001 override                                                                        |
| \$04 SYS_STATE        | -   | R   |    |    |    |      |      | 0 | 0 | 1 |   |   |   |      |      | 0  | 1 | 0 | b[10:8]: 001 =DIAG<br>b[2:0]: 010=RUN                                                                                         |
| \$6E LOOP_MATRIX_ARM1 | D   | W   | Х  | Х  | Х  | X    | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 1    | 1  | 1 | 1 | b[3:0]: ARM1 assigned to L3:L0                                                                                                |
| \$6F LOOP_MATRIX_ARM2 | D   | W   | Х  | Х  | Х  | X    | D    | W | X | Х | 1 | 1 | 1 | 1    | 0    | 0  | 0 | 0 | b[7:4]: ARM2 assigned to L7:L4                                                                                                |
| \$70 LOOP_MATRIX_ARM3 | D   | W   | Х  | Х  | Х  | Х    | 1    | 1 | 1 | 1 | 0 | 0 | 0 | 0    | 0    | 0  | 0 | 0 | b[11:8]: ARM3 assigned to LB:L8                                                                                               |





Table 51. Example of SPI message to deploy (continued)

|        |      |        |    |    |     |     |    |    | <del></del> |    | amp |    | · • · |   | - | uge |   | чор | , | ,00. |   | - | ~ <i>/</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|------|--------|----|----|-----|-----|----|----|-------------|----|-----|----|-------|---|---|-----|---|-----|---|------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | R    | egiste | r  |    | (1) | (2) | 15 | 14 | 13          | 12 | 11  | 10 | 9     | 8 | 7 | 6   | 5 | 4   | 3 | 2    | 1 | 0 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| \$02 S | YS_C | TL     |    |    | -   | W   | x  | x  | 0           | 0  | 0   | 0  | 0     | 0 | 1 | 1   | 1 | 0   | x | x    | × | × | b[13]: 0 syncbst disabled in ER state def b[12]: 0 VIN comp thresh =5.5V def b[11:10]: 00 VIBATMON comp thresh =6V def b[9]:0 ERBST 23V def. b[8,7]: 01 ER charge enabled b[6]: 1 ER BST on def. b[5]: 1 SYNC BST on def. b[4]: 0 no SPI transition to Power OFF def.                                                                                                                                                                                                                                                                                                                                                              |
| \$05 P | OWEF | R STAT | ГЕ |    |     | R   | 0  | 0  | 0           | 0  | 0   | 0  | 0     | 1 | 1 | Х   | х | 0   | 1 | 1    | 1 | 1 | b[19]: 1 WAKEUP>WU_on - expected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| (3)    | 19   | 18     | 17 | 16 |     |     | 0  | 0  | 0           | 0  | 0   | 0  | 0     | ' | ı | ^   | ^ | 0   | ' | ı    | ' | ı | b[18]: 0 VBATMON>VBBAD - expected b[17]: 0 VBATMON>VBGOOD - expected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|        | 1    | 0      | 0  | 0  |     |     |    |    |             |    |     |    |       |   |   |     |   |     |   |      |   |   | b[16]: 0 VIN>VINBAD - expected b[15]: 0 VIN>VINGOOD - expected b[14]: 0 SYNCBST>SYNCBST_OK - expected b[13]: 0 SATSUCK>SATBUCK_OK - expected b[13]: 0 ER_BST>ER_BST_OK - expected b[12]: 0 ER_BST>ER_BST_OK - expected b[11]: 0 VCC>VCC_UV expected b[10]: 0=VCC <vcc_ov -="" 0="" 1="" b[0]:="" b[1]:="" b[2]:="" b[3]:="" b[4]:="" b[5]:="" b[6]:="" b[7]:="" b[8]:="" b[9]:="" care="" curr="" disab="" disch="" don't="" er="" er_bst="" er_charge="" er_hcdis_on="" er_lcdis_on="" er_switch="" expected="" high="" low="" off="" off<="" on="" stabuck_act="" state="" sycn_bst_act="" td="" vcc_act="" vsf_act=""></vcc_ov> |

DocID030428 Rev 1

Deployment

| Table 51. Exam | nple of SPI message | to deploy | (continued) |
|----------------|---------------------|-----------|-------------|
|                |                     |           |             |

|                                        |     |     |    | Iabi | <u> </u> |    | ump | 10 01 | <u> </u> |   | - | uge |   | чср | i O y | (CO |   | ucc | A)                                                                                                                                                                                                                                                                             |
|----------------------------------------|-----|-----|----|------|----------|----|-----|-------|----------|---|---|-----|---|-----|-------|-----|---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register                               | (1) | (2) | 15 | 14   | 13       | 12 | 11  | 10    | 9        | 8 | 7 | 6   | 5 | 4   | 3     | 2   | 1 | 0   | Description                                                                                                                                                                                                                                                                    |
| \$06 DCR_0<br>\$0A DCR_4<br>\$0E DCR_8 | D   | w   | x  | x    | x        | x  | 0   | 0     | 0        | 1 | 1 | 1   | 0 | 1   | 0     | 0   | х | х   | b[11:6]: DEPLOY_TIME * 0.064ms/count up to                                                                                                                                                                                                                                     |
| \$07 DCR_1<br>\$0B DCR_5<br>\$0F DCR_9 | D   | W   | x  | Х    | Х        | х  | 0   | 0     | 0        | 1 | 1 | 1   | 1 | 0   | 0     | 0   | Х | Х   | 4.032ms max, [111] <sub>2</sub> 7*0.064ms=448µs<br>b[5:4]:<br>00, 11 not used<br>01=1.75A                                                                                                                                                                                      |
| \$08 DCR_2<br>\$0C DCR_6<br>\$10 DCR_A | D   | W   | x  | Х    | х        | x  | 0   | 0     | 0        | 1 | 1 | 1   | 0 | 1   | 0     | 0   | Х | х   | 10=1.2A<br>b[3:2]:<br>00 = 500ms                                                                                                                                                                                                                                               |
| \$09 DCR_3<br>\$0D DCR_7<br>\$11 DCR_B | D   | W   | x  | Х    | х        | х  | 0   | 0     | 0        | 1 | 1 | 1   | 1 | 0   | 0     | 0   | Х | х   | 01 = 250ms<br>10 = 125ms<br>11 = 0ms                                                                                                                                                                                                                                           |
| \$13 DSR_0. \$1E DSR_B                 | -   | R   |    |      | 0        |    |     |       |          |   |   |     |   |     |       |     |   |     | b[15]: CHiDS  0 = deployment not successful  1 = deployment successful  b[14]: CHiSTAT  0 = deployment not in progress  1 = deployment in progress  b[12]: DCRiERR  0 = depl. conf changes accepted and stored  1 = depl. conf changes rejected because deployment in progress |
| \$31 SAFING_STATE                      | D   | W   | 1  | 0    | 1        | 0  | 1   | 1     | 0        | 0 | 1 | 0   | 1 | 0   | 1     | 1   | 0 | 0   | b[15:0]: ACAC from DIAG to SAFING state                                                                                                                                                                                                                                        |
| \$04 SYS_STATE (4)                     | -   | R   |    |      |          |    |     | 0     | 1        | 0 |   |     |   |     |       | 0   | 1 | 0   | b[10:8]: 010 =SAFING<br>b[2:0]: 010=RUN                                                                                                                                                                                                                                        |
| \$6A ARM_STATE                         | -   | R   |    |      |          |    |     | 0     | 1        | 0 |   |     |   |     |       | 0   | 1 | 0   | b[5]: ARM4<br>b[4]: ARM3<br>b[3]: ARM2<br>b[2]: ARM1<br>Echo at ARMx pin                                                                                                                                                                                                       |





# Table 51. Example of SPI message to deploy (continued)

|                                |         |     |    |    |    | · <b>—</b> /\ | αιιιρ |    |   |   |   | -9- |   | - P | , | ,55 |   |   | <del>*</del> /                                                                                                       |
|--------------------------------|---------|-----|----|----|----|---------------|-------|----|---|---|---|-----|---|-----|---|-----|---|---|----------------------------------------------------------------------------------------------------------------------|
| Register                       | (1)     | (2) | 15 | 14 | 13 | 12            | 11    | 10 | 9 | 8 | 7 | 6   | 5 | 4   | 3 | 2   | 1 | 0 | Description                                                                                                          |
| \$25 SPIDEPEN                  | S,<br>A | W   | 1  | 1  | 1  | 1             | 0     | 0  | 0 | 0 | 0 | 0   | 0 | 0   | 1 | 1   | 1 | 1 | \$F00F=UNLOCK                                                                                                        |
| \$12 DEPCOM                    | S,<br>A | w   | 0  | 0  | 0  | 1             | 1     | 1  | 1 | 1 | 1 | 1   | 1 | 1   | 1 | 1   | 1 | 1 | b[i]: 3:<br>1= deploy request<br>0 = no change in deploy                                                             |
| \$25 SPIDEPEN                  | -       | R   | 0  | 0  | 0  | 0             | 1     | 1  | 1 | 1 | 1 | 1   | 1 | 1   | 0 | 0   | 0 | 0 | \$0FF0=LOCK                                                                                                          |
| \$13 DSR_0                     | -       | R   | 1  |    |    |               |       |    |   |   |   |     |   |     |   |     |   |   | b[15]: 1=CH0DS deployment successful                                                                                 |
| \$14 DSR_1                     | -       | R   | 1  |    |    |               |       |    |   |   |   |     |   |     |   |     |   |   | b[15]: 1=CH0DS deployment successful                                                                                 |
| \$15 DSR_2                     | -       | R   | 1  |    |    |               |       |    |   |   |   |     |   |     |   |     |   |   | b[15]: 1=CH0DS deployment successful                                                                                 |
| \$16 DSR_3                     | -       | R   | 1  |    |    |               |       |    |   |   |   |     |   |     |   |     |   |   | b[15]: 1=CH0DS deployment successful                                                                                 |
| \$17 DSR_4 - \$1E DSR_B        | -       | R   | 0  |    |    |               |       |    |   |   |   |     |   |     |   |     |   |   |                                                                                                                      |
| \$1F DCMTS01                   | -       | R   | 0  | 0  | 0  | 1             | 1     | 0  | 1 | 0 | 0 | 0   | 0 | 1   | 1 | 0   | 1 | 0 | curr monit timer, 16µs time resol<br>b[15:8] ch0 [11010]2 26*16µs=416µs<br>b[7:0] ch1 [11010]2 26*16µs=416µs         |
| \$20 DCMTS23                   | -       | R   | 0  | 0  | 0  | 1             | 1     | 0  | 1 | 0 | 0 | 0   | 0 | 1   | 1 | 0   | 1 | 0 | curr monit timer, 16µs time resol<br>b[15:8] ch0 [11010]2 26*16µs=416µs<br>b[7:0] ch1 [11010]2 26*16µs=416µs         |
| \$21 DCMTS46 -<br>\$24 DCMTS23 | -       | R   | 0  | 0  | 0  | 0             | 0     | 0  | 0 | 0 | 0 | 0   | 0 | 0   | 0 | 0   | 0 | 0 | curr monit timer, 16µs time resol<br>b[15:8] ch[i+1] [00000000]2 0*16µs=0µs<br>b[7:0] ] ch[i] [00000000]2 0*16µs=0µs |

<sup>1.</sup> I=INIT / D=DIAG / S=SAFING / C=SCRAP / A=ARMING / - = ALL STATES (I) = no in INIT / (D)= no in DIAG / (S)= no in SAFING / (C)= no in SCRAP / (A)= no in ARMING

<sup>2.</sup> R = READ W = WRITE

<sup>3.</sup> Further bit over the 16 standard.

<sup>4.</sup> Once a deployment has run successfully, restart from point \*5 if no parameters have to be changed.

Deployment AN5023

### \$1F DCMTS01:

b[15:8] ch0 [11010]2 26\*16  $\mu$ s = 416  $\mu$ s b[7:0] ch1 [11010]2 26\*16 $\mu$ s=416 $\mu$ s

### \$20 DCMTS23

b[15:8] ch3 [11010]2 26\*16  $\mu$ s = 416  $\mu$ s b[7:0] ch2 [11010]2 26\*16  $\mu$ s = 416  $\mu$ s

\$21 DCMTS46 - \$24 DCMTS23

b[15:8] ch[i+1] [00000000]2  $0*16 \mu s = 0 \mu s$ b[7:0] ch[i] [00000000]2  $0*16 \mu s = 0 \mu s$ 





# 7 Wheel speed sensor interface (WSS)

Aim of this section is to define a guideline and allow the user working with WSS through L9680.

L9680 is able to decode the signals coming from wheel speed sensor by means of an analog current sensing which works together with a fast ADC and a logic control unit, which allows modulating the speed information on the WSx pin.

A simplified block diagram is shown in Figure 37.



Figure 37. Wheel speed interface configuration

The IC is able to operate with several sensors: in particular the following ones have been considered

- Standard active 2-level sensor (7/14 mA): Allegro ATS682LSH
- PWM encoded 2-level sensor (7/14 mA, 1 edge per tooth): Allegro ATS651LSH
- PWM encoded 2-level sensor (7/14 mA, 2 edges per tooth): Infineon TLE4942, BOSCH DF11
- VDA compliant sensor 3-level sensor (7/14/28 mA): Philips KMI22/1

Each sensor is either able to provide simple information related to wheel speed by means of frequency variation of the output current signal (STD) or is also able to provide further diagnostic by means of duty cycle modulation (PWMs) or Manchester encoder (VDA).



#### 7.1 **SPI** configuration

In order to enable the Wheel speed interface, L9680 requires both software configurations, as described below.

- Enter in DIAG mode
- Configure sensor type (RSCRx, registers \$4A-\$4D) 2.
- Enable the WSS channels: access RSCTRL (\$4E) and enable channels

### Bench results - Allegro ATS682LSH STD sensor 7.2

Here are summarized the results obtained at bench working with different sensors. The blue waveform is the modulated current from the sensor, while the pink one is the signal on WSx pin. All the ASIC parameters, except where specified, are set at their default state.









Figure 40. STD sensor: WSx re-engagement after standstill

5

90/106 DocID030428 Rev 1

### 7.3 Bench results - Allegro ATS651LSH PWM sensor

For this kind of sensors, L9680 allows reading the pulse length of the WSS signal by means of a 9 bit counter, with a resolution of 5 µs. The value of this counter can be read via SPI in the registers RSDRx in the bit [8:0]



Figure 41. PWM1 operation 45  $\mu$ s and 90  $\mu$ s pulse @fixed speed v = v1

The results of the reading of the bit [8:0] of the registers RSDRx are reported in the table below

**Pulse length Error Actual Pulse Measured Pulse** RSDRx bit [8:0] length [µs] length [µs] [µs] [%] 45 45.88 000001001 45 1.9 91.6 000010010 90 90 1.7

Table 52. PWM1 pulse speed length measurement in RSDRx

L9680 provides the means to let the microcontroller to decode directly the waveform coming from the sensor, in pass-through mode. Such a feature can be enabled in the register (RSCRx, registers \$4A-\$4D)



Figure 42. PWM1 operation in pass-through mode

#### 7.4 Bench results Infineon TLE4942, BOSCH DF11 PWM sensors

Also for this kind of sensors, L9680 allows reading the pulse length of the WSS signal by means of a 9-bit counter, with a resolution of 5 µs. The value of this counter can be read via SPI in the registers RSDRx in the bit [8:0]. In addition, the standstill condition can be detected and properly decoded.



Figure 43. PWM2 operation 45, 90, 180, 360 and 720 µs pulse @ fixed speed

Specific test has been addressed in order to verify how the L9680 behaves in standstill condition, and to verify the suppression of the WSx commutation during standstill (feature selectable via SPI through the RSCRx registers). In both situations it has been verified that the standstill bit is set in the RSDRx registers in the bit [16].

92/106 DocID030428 Rev 1



Figure 44. PWM2 operation in standstill with SSDIS bit disabled (left) and enabled (right)

The results of the reading of the bit [8:0] of the registers RSDRx are reported in the table below:

**Actual Pulse Measured Pulse** Pulse length [µs] RSDRx bit [8:0] Error [%] length [µs] length [µs] 45 45.7 000001001 45 1.5 90 91.55 000010010 90 1.7 180 189,24 185 2.2 000100101 360 366,5 001001010 370 0.9 720 739,08 010010011 735 0.5 1440 1525 100101111 1515 0.6

Table 53. PWM2 pulse speed length measurement in RSDRx

L9680 provides the means to let the microcontroller decode the waveform coming from the sensor directly, in pass-through mode. Such a feature can be enabled in the register (RSCRx, registers \$4A-\$4D).



Figure 45. PWM2 operation in pass-through mode PWM2

#### Bench results Philips KMI22/1 VDA sensor 7.5

For this sensor, L9680 allows reading the diagnostic bit transmitted by means of a Manchester decoder. Due to the fact that the number of transmitted bit depends on the speed of the wheel, L9680 also provides a counter of the decoded bit. All this info can be read in the registers RSDRx in the bit [11:8] (counter) and bit [7:0] (data).

In addition, the standstill condition can be detected and properly decoded.



Figure 46. VDA operation 8bit + P

A specific sensor mode @high speed operation has been tested, where only two bits are sent and the new speed pulse overcomes the incoming frame: in this case both the data decoding and WSx commutation have been verified.



Figure 47. VDA operation @ high speed: 2bit message

The results of the reading of the bit [11:0] of the registers RSDRx are shown in the table below.

WSIRSDRx bit [11:8] WSIRSDRx bit [7:0] Message sent 101110101 1001 10111010 0010 01 01

Table 54. VDA message reading WSIRSDR [3:0]

Finally, the standstill operation has been verified, as shown in the next figure.

DocID030428 Rev 1 94/106



Figure 48. VDA operation in standstill: 8bit + P message

It has been verified that the correct message is decoded in the bit [16] (standstill) and [11:0] (counter + data) of the registers RSDRx.



# Appendix A Bill of materials

# Table 55. Bill of materials

| Description              | Value     | Tol. | Rating | Specific. | Package | Manufacturer | Part<br>Number                | Distr. | Order Code | UM | Qty | Designator                                                          | Notes |
|--------------------------|-----------|------|--------|-----------|---------|--------------|-------------------------------|--------|------------|----|-----|---------------------------------------------------------------------|-------|
| Printed<br>Circuit Board | ASD551C   |      |        |           |         |              |                               |        |            | NR | 1   | ASD551C                                                             |       |
| SMD<br>RESISTOR          | 0 Ohm     |      |        |           | 0603    |              |                               |        |            | NR | 11  | R31, R32,<br>R33, R34,<br>R35, R36,<br>R37, R38,<br>R38,<br>R40,R41 |       |
| SMD<br>RESISTOR          | 0,430 Ohm | 1%   |        | 1A        | 2512    | PANASONIC    | ERJ1TRQ<br>FR43U              | FN     | 1893025    | NR | 1   | R1                                                                  |       |
| SMD<br>RESISTOR          | 1K Ohm    | 5%   |        |           | 0805    |              |                               |        |            | NR | 4   | R2, R3, R5,<br>R29                                                  |       |
| SMD<br>RESISTOR          | 22K Ohm   | 5%   |        |           | 0805    |              |                               |        |            | NR | 1   | R2                                                                  |       |
| SMD<br>RESISTOR          | 300K Ohm  | 1%   | 0,125W |           | 0805    | MULTICOMP    | MCMR08X<br>3003FTL            | FN     | 2073733    | NR | 1   | R4                                                                  |       |
| SMD<br>RESISTOR          | 510Ohm    | 1%   |        |           | 0805    |              |                               |        |            | NR | 1   | R6                                                                  |       |
| SMD<br>RESISTOR          | 3K Ohm    | 1%   | 0,125W |           | 1206    | MULTICOMP    | MC<br>0.125W<br>1206 1%<br>3K | FN     | 9336311    | NR | 2   | R8, R12                                                             |       |
| SMD<br>RESISTOR          | 360 Ohm   | 5%   | 0,125W |           | 0805    |              |                               |        |            | NR | 1   | R9                                                                  |       |
| SMD<br>RESISTOR          | 1,5K Ohm  | 5%   |        |           | 0805    |              |                               |        |            | NR | 4   | R10, R11,<br>R14, R28                                               |       |
| SMD<br>RESISTOR          | 100 Ohm   | 5%   |        |           | 0805    |              |                               |        |            | NR | 1   | R13                                                                 |       |





# Table 55. Bill of materials (continued)

|                  |                 |         |        |           |         | Jili Oi illateriai | - (            | ,      |            |    |     |                                                                                                                                              |       |
|------------------|-----------------|---------|--------|-----------|---------|--------------------|----------------|--------|------------|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Description      | Value           | Tol.    | Rating | Specific. | Package | Manufacturer       | Part<br>Number | Distr. | Order Code | UM | Qty | Designator                                                                                                                                   | Notes |
| SMD<br>RESISTOR  | 4,7K Ohm        | 5%      |        |           | 0805    |                    |                |        |            | NR | 8   | R15, R16,<br>R17, R18,<br>R19, R20,<br>R21, R22                                                                                              |       |
| SMD<br>RESISTOR  | 1,5 Ohm         | 5%      |        |           | 0805    |                    |                |        |            | NR | 4   | R23, R24,<br>R25, R26                                                                                                                        |       |
| SMD<br>RESISTOR  | 1,8K Ohm        | 5%      |        |           | 0805    |                    |                |        |            | NR | 1   | R27                                                                                                                                          |       |
| SMD<br>CAPACITOR | 100nF /<br>100V | 20 %    | 100V   |           | 0805    |                    |                |        |            | NR | 22  | C1, C5, C7,<br>C8, C9,<br>C11, C12,<br>C14, C21,<br>C23_1,<br>C23_2,<br>C24, C25,<br>C41, C42,<br>C43, C44,<br>C45, C46,<br>C81, C82,<br>C83 |       |
| SMD<br>CAPACITOR | 10nF / 25V      | 20<br>% | 25V    |           | 0805    |                    |                |        |            | NR | 8   | C10, C20,<br>C27, C28,<br>C29, C30,<br>C31, C32                                                                                              |       |

Bill of materials

| Table 55. Bill of materials ( | continued) |
|-------------------------------|------------|
|-------------------------------|------------|

| Description                   | Value       | Tol.    | Rating | Specific. | Package | Manufacturer | Part<br>Number             | Distr. | Order Code | UM | Qty | Designator                                                                                                                                                                                                                                    | Notes           |
|-------------------------------|-------------|---------|--------|-----------|---------|--------------|----------------------------|--------|------------|----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| SMD<br>CAPACITOR              | 22nF / 25V  | 20<br>% | 25V    |           | 0805    |              |                            |        |            | NR | 37  | C37, C38,<br>C39, C40,<br>C47, C48,<br>C49, C50,<br>C51, C52,<br>C53, C54,<br>C55, C56,<br>C57, C58,<br>C59, C60,<br>C61, C62,<br>C63, C64,<br>C65, C66,<br>C67, C68,<br>C69, C70,<br>C71, C72,<br>C73, C74,<br>C75, C76,<br>C77, C78,<br>C79 |                 |
| SMD<br>CAPACITOR              | 3,3nF / 25V | 20<br>% | 25V    |           | 0805    |              |                            |        |            | NR | 4   | C33, C34,<br>C35, C36                                                                                                                                                                                                                         |                 |
| SMD<br>CAPACITOR              | 4,7nF / 25V | 20<br>% | 25V    |           | 0805    |              |                            |        |            | NR | 1   | C80                                                                                                                                                                                                                                           |                 |
| SMD<br>CAPACITOR              | 2,2uF / 50V | 20<br>% | 50V    |           | 0805    |              |                            |        |            | NR | 5   | C2_1, C3,<br>C84,<br>C85_1,<br>C86_1                                                                                                                                                                                                          |                 |
| SMD<br>TAMTALIUM<br>CAPACITOR | 10uF / 35V  | 20<br>% | 35V    |           | D       |              |                            |        |            | NR | 3   | C13, C22,<br>C26                                                                                                                                                                                                                              |                 |
| SMD<br>TAMTALIUM<br>CAPACITOR | 47uF / 35V  | 20<br>% | 35V    |           | Х       | KEMET        | T495X476<br>K035ATE3<br>00 | FN     | 1794757    | NR | 3   | C2_2,<br>C85_2,<br>C86_2                                                                                                                                                                                                                      | Do not populate |



# Table 55. Bill of materials (continued)

| Description                       | Value                    | Tol.    | Rating | Specific. | Package       | Manufacturer                   | Part<br>Number   | Distr. | Order Code | UM | Qty | Designator                             | Notes |
|-----------------------------------|--------------------------|---------|--------|-----------|---------------|--------------------------------|------------------|--------|------------|----|-----|----------------------------------------|-------|
| ELECTROLI<br>TIC<br>CAPACITOR     | 10uF / 100V              | 20<br>% | 100V   |           | RB.1/.2       |                                |                  |        |            | NR | 1   | C4                                     |       |
| ELECTROLI<br>TIC<br>CAPACITOR     | 100uF / 50V              | 20<br>% | 50V    |           | RB.15/.32     |                                |                  |        |            | NR | 1   | C6                                     |       |
| ELECTROLI<br>TIC<br>CAPACITOR     | 2200-<br>4700uF /<br>50V | 20<br>% | 50V    |           | RB.4/1.2      | PANASONIC                      | ECOS1HA<br>472DA | FN     | 1198550    | NR | 1   | C15                                    |       |
| SMD<br>INDUCTOR                   | 4,7uH/1A                 | 20<br>% | 1A     |           | B82462A<br>4  | EPCOS                          | B82462A4<br>472M | FN     | 7429819    | NR | 3   | L2, L3, L4                             |       |
| SMD<br>INDUCTOR                   | 10uH / 1A                | 20<br>% | 1A     |           | B82462A<br>4  | EPCOS                          | B82462A4<br>103W | FN     | 7429835    | NR | 1   | L1                                     |       |
| DIODE<br>SCHOTTKY<br>1A 40V       | SS14                     |         | 1A     | 40V       | SMA           | FAIRCHILD<br>SEMICONDU<br>CTOR | SS14             | FN     | 1467537    | NR | 1   | D1                                     |       |
| DIODE<br>HIGH<br>SPEED 1A<br>100V | LL4148                   |         | 1A     | 100V      | MINIMEL<br>3  |                                |                  |        |            | NR | 1   | D4                                     |       |
| SMD DIODE<br>1A 1000V             | GS1M                     |         | 1A     | 1000V     | SMA           |                                |                  |        |            | NR | 8   | D3, D5, D6,<br>D7, D8, D9,<br>D10, D11 |       |
| DIODE<br>SCHOTTKY<br>1A 60V       | SS16                     |         | 1A     | 60V       | SMA           | MULTICOMP                      | SS16             | FN     | 4085167    | NR | 1   | D12                                    |       |
| DIODE<br>ZENER 15V                | 15V /<br>0,500W          |         | 15V    | 0,500W    | MINIMEL<br>F2 |                                |                  |        |            | NR | 2   | DZ1, DZ2                               |       |
| TVS<br>BIDIRECTIO<br>NAL DIODE    | SM6T33CA                 |         |        |           | SMB           | ST<br>Microelectroni<br>cs     | SM6T33C<br>A     | FN     | 9802681    | NR | 1   | D2                                     |       |

Bill of materials

Table 55. Bill of materials (continued)

| Description                      | Value     | Tol. | Rating | Specific. | Package                     | Manufacturer               | Part<br>Number  | Distr. | Order Code | UM | Qty | Designator | Notes |
|----------------------------------|-----------|------|--------|-----------|-----------------------------|----------------------------|-----------------|--------|------------|----|-----|------------|-------|
| DUAL<br>TRANSISTO<br>R NPN/PNP   | PUMD15    |      |        |           | SOT-363                     | NXP                        | PUMD15          | FN     | 8738335    | NR | 2   | U4, U5     |       |
| MOSFET P-<br>Channel             | STD10PF06 |      |        |           | DPAK                        | ST<br>Microelectroni<br>cs | STD10PF<br>06T4 | FN     | 1468000    | NR | 1   | Q1         |       |
| MOSFET N-<br>Channel             | STD60NF06 |      |        |           | DPAK                        | ST<br>Microelectroni<br>cs | STD60NF<br>06T4 | FN     | 9935436    | NR | 1   | Q2         |       |
| PNP<br>BIPOLAR<br>TRANSISTO<br>R | BCP53-10  |      |        |           | SOT223                      | NXP                        | BCP53-10        | FN     | 8734810    | NR | 2   | Q3, Q4     |       |
| NPN<br>TRANSISTO<br>R            | BCP56     |      |        |           | SOT223                      | NXP                        | BCP56           | FN     | 1081257    | NR | 1   | Q5         |       |
| L9678                            | L9678     |      |        |           | TQFP64_<br>L                | ST<br>Microelectroni<br>cs | L9678           |        |            | NR | 1   | U1         |       |
| L9679                            | L9679     |      |        |           | TQFP100<br>_EXPOS<br>ED PAD | ST<br>Microelectroni<br>cs | L9679           |        |            | NR | 1   | U2         |       |
| L9680                            | L9680     |      |        |           | TQFP100<br>_EXPOS<br>ED PAD | ST<br>Microelectroni<br>cs | L9680           |        |            | NR | 1   | U3         |       |





DocID030428 Rev 1

| 101/106 |
|---------|

|                                       | Table 55. Bill of materials (continued) |      |             |           |                       |              |                 |          |                                    |    |     |                                                                                                                                                                                                                               |                 |
|---------------------------------------|-----------------------------------------|------|-------------|-----------|-----------------------|--------------|-----------------|----------|------------------------------------|----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| Description                           | n Value                                 | Tol. | Rating      | Specific. | Package               | Manufacturer | Part<br>Number  | Distr.   | Order Code                         | UM | Qty | Designator                                                                                                                                                                                                                    | Notes           |
| TEST<br>POINT                         |                                         |      |             |           | TEST<br>POINT         |              |                 |          |                                    | NR | 36  | TP1, TP2, TP3, TP4, TP5, TP6, TP7, TP8, TP9, TP10, TP11, TP12, TP13, TP14, TP15, TP16, TP17, TP18, TP19, TP20, TP21, TP22, TP23, TP24, TP25, TP26, TP27, TP28, TP26, TP27, TP28, TP29, TP30, TP31, TP32, 33, TP34, TP35, TP36 |                 |
| AUTOMOT<br>VE<br>CONNECTO<br>R 80 WAY | 502225-<br>0 0801                       |      | 80<br>POLES | MALE      | SD-<br>502225-<br>001 | MOLEX        | 502225-<br>0801 | FN<br>MO | 1874028<br>538-<br>502225-<br>0801 | NR | 1   | J30                                                                                                                                                                                                                           |                 |
| CONNECTO<br>R CART                    | p. 7.62mm                               |      |             |           | GMKDS<br>3/2-7.62     |              |                 |          |                                    | NR | 1   | J4                                                                                                                                                                                                                            | Do not populate |

Bill of materials

| Table 55. | Bill of | materials | (continued) |
|-----------|---------|-----------|-------------|
|-----------|---------|-----------|-------------|

| Description                                     | Value                         | Tol. | Rating       | Specific.       | Package               | Manufacturer | Part<br>Number     | Distr. | Order Code | UM | Qty | Designator                      | Notes                                                       |
|-------------------------------------------------|-------------------------------|------|--------------|-----------------|-----------------------|--------------|--------------------|--------|------------|----|-----|---------------------------------|-------------------------------------------------------------|
| HEADER<br>3X1                                   | p. 2.54mm                     |      | 3 POLES      | MALE            | SIP3                  |              |                    |        |            | NR | 6   | J3, J6, J7,<br>J11, J12,<br>J28 |                                                             |
| GOUTTE<br>CONTACT                               |                               |      |              |                 | JUMP A<br>SALDAR<br>E |              |                    |        |            | NR | 3   | J1, J13, J20                    |                                                             |
| HEADER "T"<br>TIPE                              | p. 2.54mm                     |      | 4 POLES      | MALE            | SIP4-T                |              |                    |        |            | NR | 2   | J15, J16                        |                                                             |
| HEADER<br>2X1                                   | p. 2.54mm                     |      | 2 POLES      | MALE            | SIP2                  |              |                    |        |            | NR | 6   | J2, J5, J8,<br>J9, J17, J29     |                                                             |
| HEADER<br>7X1                                   | p. 2.54mm                     |      | 7 POLES      | MALE            | SIP7                  |              |                    |        |            | NR | 2   | J18, J19                        |                                                             |
| HEADER<br>34X4                                  | p. 2.54mm                     |      | 136<br>POLES | MALE/FE<br>MALE | IDC34X4               | SAMTEC       | ESQ-134-<br>14-G-D | FN     | 1769251    | NR | 1   | J10                             | Each<br>connector is<br>composed<br>by 2 ESQ-<br>134-14-G-D |
|                                                 |                               |      |              | IN              | FORMATIO              | N ABOUT MECI | HANICAL PA         | ARTS   |            |    |     |                                 |                                                             |
| JUMPER<br>CONFIGUR<br>ATION                     |                               |      | 2 POLES      | FEMALE          |                       |              |                    |        |            | NR | 14  |                                 | Provide in envelope                                         |
|                                                 | INFORMATION ABOUT SPARE PARTS |      |              |                 |                       |              |                    |        |            |    |     |                                 |                                                             |
| FEMALE<br>AUTOMOTI<br>VE<br>CONNECTO<br>R 48WAY |                               |      | 48<br>POLES  | FEMALE          |                       | MOLEX        | 64320-<br>1319     | FN     | 2060665    | NR | 1   |                                 |                                                             |





Table 55. Bill of materials (continued)

| Description                                     | Value | Tol. | Rating      | Specific. | Package | Manufacturer | Part<br>Number | Distr.   | Order Code          | UM | Qty | Designator | Notes            |
|-------------------------------------------------|-------|------|-------------|-----------|---------|--------------|----------------|----------|---------------------|----|-----|------------|------------------|
| FEMALE<br>AUTOMOTI<br>VE<br>CONNECTO<br>R 32WAY |       |      | 32<br>POLES | FEMALE    |         | MOLEX        | 64319-<br>3211 | FN       | 1874144             | NR | 1   |            |                  |
| TERMINAL<br>14-16 AWG                           |       |      |             | FEMALE    |         | MOLEX        | 64323-<br>1039 | FN       | 2060654             | NR | 16  |            |                  |
| TERMINAL<br>0,5MM2                              |       |      |             | FEMALE    |         | MOLEX        | 64322-<br>1039 | FN<br>RS | 1830393<br>723-9362 | NR | 64  |            |                  |
| JACK<br>BANANA<br>WHITE                         | 4mm   |      |             | WHITE     |         |              |                | FN       | 110-1105            | NR | 6   |            |                  |
| JACK<br>BANANA<br>YELLOW                        | 4mm   |      |             | YELLOW    |         |              |                | FN       | 110-1104            | NR | 2   |            |                  |
| JACK<br>BANANA<br>GREEN                         | 4mm   |      |             | GREEN     |         |              |                | FN       | 110-1102            | NR | 4   |            |                  |
| JACK<br>BANANA<br>BLUE                          | 4mm   |      |             | BLUE      |         |              |                | FN       | 110-1103            | NR | 9   |            |                  |
| JACK<br>BANANA<br>RED                           | 4mm   |      |             | RED       |         |              |                | FN       | 110-1098            | NR | 17  |            |                  |
| JACK<br>BANANA<br>BLACK                         | 4mm   |      |             | BLACK     |         |              |                | FN       | 110-1101            | NR | 16  |            |                  |
| RED CABLE<br>1mmq -<br>LEGHT=<br>70cm           | 1mmq  |      |             | RED       |         |              |                |          |                     | NR | 4   |            | Lenght =<br>70cm |

Bill of materials

Table 55. Bill of materials (continued)

| Description                                    | Value   | Tol. | Rating | Specific. | Package | Manufacturer | Part<br>Number | Distr. | Order Code | UM | Qty | Designator | Notes            |
|------------------------------------------------|---------|------|--------|-----------|---------|--------------|----------------|--------|------------|----|-----|------------|------------------|
| RED CABLE<br>0.35mmq -<br>LEGHT=<br>70cm       | 0.35mmq |      |        | RED       |         |              |                |        |            | NR | 13  |            | Lenght =<br>70cm |
| BLACK<br>CABLE<br>0.35mmq -<br>LEGHT=<br>70cm  | 0.35mmq |      |        | BLACK     |         |              |                |        |            | NR | 16  |            | Lenght =<br>70cm |
| WHITE<br>CABLE<br>0.35mmq -<br>LEGHT=<br>70cm  | 0.35mmq |      |        | WHITE     |         |              |                |        |            | NR | 6   |            | Lenght =<br>70cm |
| YELLOW<br>CABLE<br>0.35mmq -<br>LEGHT=<br>70cm | 0.35mmq |      |        | YELLOW    |         |              |                |        |            | NR | 2   |            | Lenght =<br>70cm |
| GREEN<br>CABLE<br>0.35mmq -<br>LEGHT=<br>70cm  | 0.35mmq |      |        | GREEN     |         |              |                |        |            | NR | 4   |            | Lenght =<br>70cm |
| BLUE<br>CABLE<br>0.35mmq -<br>LEGHT=<br>70cm   | 0.35mmq |      |        | BLUE      |         |              |                |        |            | NR | 9   |            | Lenght =<br>70cm |



AN5023 Revision history

# **Revision history**

Table 56. Document revision history

| Date        | Revision | Changes          |
|-------------|----------|------------------|
| 21-Dec-2017 | 1        | Initial release. |

### **IMPORTANT NOTICE - PLEASE READ CAREFULLY**

STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgement.

Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers' products.

No license, express or implied, to any intellectual property right is granted by ST herein.

Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product.

ST and the ST logo are trademarks of ST. All other product or service names are the property of their respective owners.

Information in this document supersedes and replaces information previously supplied in any prior versions of this document.

© 2017 STMicroelectronics - All rights reserved

